js原生实现省市两级联动

因为引Jquery太麻烦了,尝试用原生写一个关于省级联动这种类似功能的。


实现效果

这里想要的效果是如果选择省份,自动出现省份对应的城市 

首先,后台返回的数据结构是这样子的

然后,我要把这些需要展示联动的关键字剥离开来,在这儿就是cityName,和它的store里面的address

result.map(item=>{

                        city.push({label:item.cityName,store:item.store});

                    })

                    city.map((item,index) =>{

                        var city = item.label;

                        temp = [];

                        if(item.store.length > 1){

                            item.store.map((item,index)=>{

                                temp.push(item.shopName);

                            })

                            area[city] = temp;

                        }else {

                            area[city] = [item.store[0].shopName];

                        }   

                    })  

                    console.log(area);

把这些数据处理完之后,出现这样的效果

接下来,html结构

<select id="selProvince" onchange="changeCity()">

  <option>请选择省份</option>

</select>

<select id="selCity">

  <option>请选择城市</option>

</select>

第一,这个是为了更简单的写语句,类似于Jquery的写法

function $(ID){ 

        return document.getElementById(ID);

    } // 

第二步,把整理好的数据,塞到各个option里面

    var province = $("selProvince");

                    for (var i in area) {

                        province.add(new Option(i,i),null);

                    }   


第三,动态响应,触发onchange事件,选择哪个,就出来相对应的option

    function changeCity(){

            var province = $("selProvince").value;

            var city = $("selCity");

            city.options.length = 0;

            for (var i in area) {

                if(i == province){

                    for (var j in area[i]) {

                        city.add(new Option(area[i][j],area[i][j]),null);

                    }

                }

            }

        }

其中用到两个知识点

一、add(),引用官方解释

定义和用法

add() 方法用于向 <select> 添加一个 <option> 元素。

语法

selectObject.add(option,before)

参数描述

option必需。要添加选项元素。必需是 option 或 optgroup 元素。

before必需。在选项数组的该元素之前增加新的元素。如果该参数是null,元素添加到选项数组的末尾。

二、new option(); 一般用在动态生成选择项目

new Option("显示的文本labe","值value",true,true)

后面两个true分别表示默认被选中和有效!,可写可不写

最后文章的末尾放上所有代码 :


<!DOCTYPE html>

<html lang="zh">

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>title</title>

</head>

<body>

<select id="selProvince" onchange="changeCity()">

  <option>请选择省份</option>

</select>

<select id="selCity">

  <option>请选择城市</option>

</select>

<script >

    window.onload = function(){

        if(window.XMLHttpRequest){

            var oAjax = new XMLHttpRequest();//创建ajax对象

        }else {

            var oAjax = new ActiveXObject("Microsoft.XMLHTTP");

        }

        oAjax.open("Post","XXXXXX请求的接口地址",true); 

        oAjax.send();

        oAjax.onreadystatechange = function(){

            if(oAjax.readyState == 4) {

                if(oAjax.status == 200){     

                    result = JSON.parse(oAjax.responseText).resultData.result_org;

                    city= [];

                    area = [];

                    result.map(item=>{

                        city.push({label:item.cityName,store:item.store});

                    })

                    city.map((item,index) =>{

                        var city = item.label;

                        temp = [];

                        if(item.store.length > 1){

                            item.store.map((item,index)=>{

                                temp.push(item.shopName);

                            })

                            area[city] = temp;

                        }else {

                            area[city] = [item.store[0].shopName];

                        }   

                    })  

                    var province = $("selProvince");

                    for (var i in area) {

                        province.add(new Option(i,i),null);

                    }   

                }else{

                    console.log("失败");

                }

            }

        };


    }

    function $(ID){ 

        return document.getElementById(ID);

    }

    function changeCity(){

            var province = $("selProvince").value;

            var city = $("selCity");

            city.options.length = 0;

            for (var i in area) {

                if(i == province){

                    for (var j in area[i]) {

                        city.add(new Option(area[i][j],area[i][j]),null);

                    }

                }

            }

    }

</script>

</body>

</html>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,242评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,769评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,484评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,133评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,007评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,080评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,496评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,190评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,464评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,549评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,330评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,205评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,567评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,889评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,160评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,475评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,650评论 2 335

推荐阅读更多精彩内容

  • Lua 5.1 参考手册 by Roberto Ierusalimschy, Luiz Henrique de F...
    苏黎九歌阅读 13,674评论 0 38
  • pyspark.sql模块 模块上下文 Spark SQL和DataFrames的重要类: pyspark.sql...
    mpro阅读 9,422评论 0 13
  • 2018年8月26日 星期日~晴 亲子日记第40天 根据学校安排,今天“父母大课堂”又开讲了,由于老师们要参加视频...
    翟婧婷爸爸阅读 1,239评论 3 6
  • 站在学校东南门外的天桥上,看明黄色的路灯,和时不时呼啸过的车。良久,觉得该写点什么了,继而转身往回走。有意无意地看...
    韩半两阅读 277评论 1 1
  • 今天,关于简书的问题我求助了弘丹。她帮助我解决了问题并给我提了一个建议:多多写写关于音乐方面的内容与大家分享。 于...
    喜水阅读 1,445评论 6 9