省市聯動效果

来源:http://www.cnblogs.com/White-Quality/archive/2016/06/06/5562692.html
-Advertisement-
Play Games

下拉框二級聯動效果在日常應用場景中經常會碰到,尤其是涉及地區、品種等有多級選項時。例如:常見的省市聯動下拉框,在選擇省份時,城市列表也會更隨改變。 思路: 1,所謂聯動效果,是指出發父級的數據變化時,會影響到關聯性子級數據元素的變化。 下麵是造的省市的數據: var linkDatas = { pr ...


下拉框二級聯動效果在日常應用場景中經常會碰到,尤其是涉及地區、品種等有多級選項時。例如:常見的省市聯動下拉框,在選擇省份時,城市列表也會更隨改變。

思路:

1,所謂聯動效果,是指出發父級的數據變化時,會影響到關聯性子級數據元素的變化。

下麵是造的省市的數據:

var linkDatas = {
            provinces:[
                {
                    "code":"0",
                    "name":"請選擇"
                },
                {
                    "code":"1",
                    "name":"北京"
                },
                {
                    "code":"2",
                    "name":"天津"
                },
                {
                    "code":"3",
                    "name":"河北"
                },
                {
                    "code":"4",
                    "name":"湖北"
                },
                {
                    "code":"5",
                    "name":"廣東"
                },
                {
                    "code":"6",
                    "name":"其他"
                }
            ],
            citys:{
                0:[
                    "請選擇"
                ],
                1:[
                    "朝陽區",
                    "海澱區",
                    "東城區",
                    "西城區",
                    "房山區",
                    "其他"
                ],
                2:[
                    "天津"
                ],
                3:[
                    "滄州",
                    "石家莊",
                    "秦皇島",
                    "其他"
                ],
                4:[
                    "武漢市",
                    "宜昌市",
                    "襄樊市",
                    "其他"
                ],
                5:[
                    "廣州市",
                    "深圳市",
                    "汕頭市",
                    "佛山市",
                    "珠海市",
                    "其他"
                ],
                6:[
                    "其他"
                ]
            }
            };
View Code

2,根據數據動態生成option節點:

function addOptions(target,options){
                var optionEle = null,
                        target = target,
                        option = options,
                        optionLen = options.length;
                for(var i = 0;i < optionLen;i++){
                    optionEle = document.createElement('option');
                    optionEle.value = option[i].value;
                    optionEle.text = option[i].text;
                    target.options.add(optionEle);
                }
            }

3,根據上述省市數據,其中code代表“省級”指向“城市”的標識符,當省級的數據變更時,出發change事件:

pro.onchange = function(){
                    console.log(this);
                    var ct = city[this.value],
                            ctLen = ct.length,
                            ctBox = [];

                    c.innerHTML = "";    
                    /*添加城市*/    
                    for(var j = 0;j < ctLen;j++){
                        ctBox.push({
                            "text" : ct[j],
                            "value": ct[j]
                        });
                    }
                    addOptions(c,ctBox);
                }

HTML代碼:

<div class="content">
            <h3>下拉框聯動效果</h3>
            <p>省份:
                <select name="provinces" id="provinces">
                    
                </select>
            </p>
            <p>
                市:
                <select name="citys" id="citys">
                    
                </select>
            </p>
        </div>

全部JavaScript代碼:

var linkDatas = {
            provinces:[
                {
                    "code":"0",
                    "name":"請選擇"
                },
                {
                    "code":"1",
                    "name":"北京"
                },
                {
                    "code":"2",
                    "name":"天津"
                },
                {
                    "code":"3",
                    "name":"河北"
                },
                {
                    "code":"4",
                    "name":"湖北"
                },
                {
                    "code":"5",
                    "name":"廣東"
                },
                {
                    "code":"6",
                    "name":"其他"
                }
            ],
            citys:{
                0:[
                    "請選擇"
                ],
                1:[
                    "朝陽區",
                    "海澱區",
                    "東城區",
                    "西城區",
                    "房山區",
                    "其他"
                ],
                2:[
                    "天津"
                ],
                3:[
                    "滄州",
                    "石家莊",
                    "秦皇島",
                    "其他"
                ],
                4:[
                    "武漢市",
                    "宜昌市",
                    "襄樊市",
                    "其他"
                ],
                5:[
                    "廣州市",
                    "深圳市",
                    "汕頭市",
                    "佛山市",
                    "珠海市",
                    "其他"
                ],
                6:[
                    "其他"
                ]
            }
            };
            function addOptions(target,options){
                var optionEle = null,
                        target = target,
                        option = options,
                        optionLen = options.length;
                for(var i = 0;i < optionLen;i++){
                    optionEle = document.createElement('option');
                    optionEle.value = option[i].value;
                    optionEle.text = option[i].text;
                    target.options.add(optionEle);
                }
            }
            function provincesCitysLink(pro,c){
                var LD                 = linkDatas,
                        provinces = LD.provinces,
                        city             = LD.citys,
                        initCity    = city[0],
                        proBox        = [];

                /*添加省份*/
                for(var i = 0;i < provinces.length;i++){
                    proBox.push({
                        "text" : provinces[i].name,
                        "value": provinces[i].code
                    })
                }        
                addOptions(pro,proBox);

                /*初始化城市*/
                addOptions(c,[{
                    "text" : initCity,
                    "value": initCity
                }]);

                /*添加聯動事件*/
                pro.onchange = function(){
                    console.log(this);
                    var ct = city[this.value],
                            ctLen = ct.length,
                            ctBox = [];

                    c.innerHTML = "";    
                    /*添加城市*/    
                    for(var j = 0;j < ctLen;j++){
                        ctBox.push({
                            "text" : ct[j],
                            "value": ct[j]
                        });
                    }
                    addOptions(c,ctBox);
                }
            }
            var provinces = document.getElementById('provinces'),
                    citys         = document.getElementById('citys');
            provincesCitysLink(provinces,citys);

 

 

 

 

 

 

DEMO演示:CLICK ME!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在我們平時寫代碼的時候沒有沒有掌握一些CSS技巧呢? 今天給大家分享一個《CSS 高級技巧彙總讓你的代碼簡潔高效》。大家務必掌握這些小技巧,會讓你非常高效率的寫出網頁的。 ◆使用 :not() 在菜單上應用/取消應用邊框 先給每一個菜單項添加邊框 ……然後再除去最後一個元素…… ……可以直接使用 : ...
  • 如果我們需要向組件傳遞參數,可以使用 this.props 對象,實例如下: <body> <div id="example"></div> <script type="text/babel"> var HelloMessage = React.createClass({ render: funct ...
  • javascript之基本包裝類型 學習要點: 基本包裝類型概述 Boolean類型 Number類型 String類型 一、基本包裝類型概述 為了便於操作基本類型值,提供了3種特殊的引用類型:Boolean,Number和String。 二、Boolean類型 new Boolean(value) ...
  • 至今HTML5中國已經為大家分享過幾百種基於 CSS3 的Loading載入動畫,效果酷炫代碼簡潔,非常值得學習借鑒;今天就先給大家分享兩個常用的CSS3的Loading的案例。 第一種效果: HTML部分 CSS3部分 第二種效果: HTML部分 CSS3部分 上面這兩個都是大家常用的載入效果,下 ...
  • 對象是js中的一種基本的數據類型,除了可以給自身附屬性外,javascript對象還可以從一個稱為原型的對象繼承屬性。這種“原型式繼承”是javascript的核心特征。 在javascript中,創建一個對象通常可以有三個方法,對象直接量,關鍵字new和Object.create()函數。接下來會 ...
  • 1.escape() 不能直接用於URL編碼,它的真正作用是返回一個字元的Unicode編碼值。比如“春節”的返回結果是%u6625%u8282,escape()不對"+"編碼主要用於漢子編碼,現在已經不提倡使用了。 2.encodeURI()是javascript中真正用來對URL編碼的函數。編碼 ...
  • Node.js是一個基於Chrome JavaScript運行時建立的平臺,小巧方便搭建。運行的埠可以在瀏覽器上運行,顯示效果,但每次用瀏覽器也挺麻煩,我們這裡講的是在sublime text2中配置,是的js在sublimetext2中運行,再也不用切換到瀏覽器了。 1.首先安裝node.js, ...
  • ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...