哇塞 我初学javascript第1天就会使用原生数组+JSON+DOM实现了国家--城市--区县三级联动数据切换效果

简介: 使用原生数组+JSON+DOM实现了国家--城市--区县三级联动数据切换

🚀 个人主页 极客小俊
✍🏻 作者简介:web开发者、设计师、技术分享博主
🐋 希望大家多多支持一下, 我们一起进步!😄
🏅 如果文章对你有帮助的话,欢迎评论 💬点赞👍🏻 收藏 📂加关注

1.png

我们今天来使用纯javascript来实现一个简易的三级联动效果,不使用任何框架以及插件!😃😃😃

Javascript + JSON数据 实现三级联动 😏

准备数据 🚀

这里我们就用测试JSON数据即可, 数据内容你可以随意!
如下

var data=[
 {
   
   "name":'中国',"val":"ch","city":
     [
         {
   
   "name":"重庆市","val":"cqs","area":[
                 {
   
   "name":"渝中区"},
                 {
   
   "name":"江北区"}
             ]
         },
         {
   
   "name":"深圳市","val":"szs","area":[
                 {
   
   "name":"浦东"},
                 {
   
   "name":"浦西"}
             ]
         }
     ]
 },

 {
   
   "name":'美国',"val":"ag","city":
     [
         {
   
   "name":"纽约","val":"newyork","area":[
                 {
   
   "name":"皇后区"},
                 {
   
   "name":"时代广场"}
             ]
         },
         {
   
   "name":"华盛顿","val":"hsd","area":[
                 {
   
   "name":"白宫"},
                 {
   
   "name":"神盾局"}
             ]
         }
     ]
 }

];

HTML代码结构🧱

国家:<select id="pro">
<option value="">请选择省份</option>
</select>
城市: <select id="city">
<option value="">请选择市</option>
</select>
地区: <select id="area">
<option value="">请选择区</option>
</select>

javascript代码逻辑 🛎️


        var _pro=document.getElementById("pro");
        var _city=document.getElementById("city");
        var _area=document.getElementById("area");

        for(var i=0;i<data.length;i++){
   
   
            var _op=document.createElement("option");
            _op.value=data[i].val;
            _op.innerHTML=data[i].name;
            _pro.appendChild(_op);
        };


        _pro.onchange=function(){
   
   
            _city.innerHTML="";
            _area.innerHTML="";

            if(this.value==""){
   
   
                var _oPempty1=document.createElement("option");
                _oPempty1.value=''
                _oPempty1.innerHTML='请选择市';
                _city.appendChild(_oPempty1);

                var _oPempty2=document.createElement("option");
                _oPempty2.value=''
                _oPempty2.innerHTML='请选择区';
                _area.appendChild(_oPempty2);
            }else{
   
   
                for(var i=0;i<data.length;i++){
   
   
                    if(this.value==data[i].val){
   
     
                            for(var j=0;j<data[i].city.length;j++){
   
     

                                    var _op2=document.createElement("option");
                                    _op2.value=data[i].city[j].val;  
                                    _op2.innerHTML=data[i].city[j].name;
                                    _city.appendChild(_op2);
                            }

                        for(var j=0;j<data[i].city[0].area.length;j++){
   
   
                                    var _op3=document.createElement("option");
                                    _op3.value=data[i].city[0].area[j].name;
                                    _op3.innerHTML=data[i].city[0].area[j].name;
                                    _area.appendChild(_op3);
                        }
                    }
                }
            }
        }


        _city.onchange=function(){
   
   
            _area.innerHTML="";
            for(var i=0;i<data.length;i++){
   
   
                for(var j=0;j<data[i].city.length;j++){
   
   
                    if(data[i].city[j].val==this.value){
   
   
                       var len=data[i].city[j].area.length;
                        for(var k=0;k<len;k++){
   
   
                            var _op4=document.createElement("option");
                            _op4.value=data[i].city[j].area[k].name;
                            _op4.innerHTML=data[i].city[j].area[k].name;
                            _area.appendChild(_op4);
                        }
                    }
                }
            }
        }

最终效果如下:

如图
2.gif

这就是使用js+json来实现简易的三级联动的效果!
对于html结构美化大家可以自行使用css样式进行美化,这里就不过多赘述了!


那么接下来,我们可以使用js+数组的形式, 也来实现一下这个三级联动的效果

JS三级联动数组数据格式 🛢️

如下

var arr=['中国','美国','日本'];
        arr['中国']=['重庆市','北京市','上海市'];
        arr['美国']=['纽约','华盛顿','阿拉斯加'];
        arr['日本']=['东京','大阪','名古屋'];

        arr['重庆市']=['解放碑','沙坪坝','九龙坡'];
        arr['北京市']=['天安门','朝阳区','海淀区'];
        arr['上海市']=['黄浦江','东方明珠','黄浦区','虹口机场'];

        arr['纽约']=['皇后区','时代广场','布朗克斯区'];
        arr['华盛顿']=['林肯纪念堂','白宫','美国国会图书馆'];
        arr['阿拉斯加']=['蕨草镇'];

        arr['东京']=['东京迪士尼','银座','东京塔'];
        arr['大阪']=['天守阁','天保山海游','四天王寺'];
        arr['名古屋']=['热田神宫'];

HTML代码结构 🧱

国家:<select id="country"></select>
城市:<select id="province"></select>
地区:<select id="area"></select>

javascript代码实现逻辑 🛎️

function init(){
   
   
     fillData(arr,'country');
     fillData(arr['中国'],'province');
     fillData(arr['重庆市'],'area');

 }


 function fillData(arr,id){
   
   
     var obj=document.getElementById(id);
     obj.options.length=0;
     var i=0;
     var len=arr.length;
     for(;i<len;i++){
   
   
         var _Option = new Option();
         _Option.text=arr[i];
         _Option.value=arr[i];
         obj.add(_Option);
     }
 }

 function chchangePro(StrIndex){
   
   
     fillData(arr[StrIndex],'province');
     fillData(arr[arr[StrIndex][0]],'area');
 }

 function changeArea(StrIndex){
   
   
     fillData(arr[StrIndex],'area');
 }


 window.onload=function () {
   
   
     //初始化效果
     init();

     var _country=document.getElementById('country');
     var _province=document.getElementById('province');
     _country.onchange=function () {
   
   
         chchangePro(this.value);
     }

     _province.onchange=function () {
   
   
         changeArea(this.value);
     }

 }

最后实现效果

如图
3.gif

怎么样,js+数组也可以实现这种效果。哈哈哈哈 🛕🛕🛕

总结想法和思路💡

好了我大致总结了一下思路
如下:

  1. 最重要的就是先要把数组和JSON的数据结构理解清楚,然后把数据的存储结构先写出来.
  2. For循环的结构思路要清晰,
  3. 创建元素要在for循环中.
  4. onchange事件的使用, 当值发生变化的时候触发某一个方法.
  5. 每次调用取值函数的时候清空一下
相关文章
|
4月前
|
JSON API 数据格式
淘宝拍立淘按图搜索API系列,json数据返回
淘宝拍立淘按图搜索API系列通过图像识别技术实现商品搜索功能,调用后返回的JSON数据包含商品标题、图片链接、价格、销量、相似度评分等核心字段,支持分页和详细商品信息展示。以下是该API接口返回的JSON数据示例及详细解析:
|
4月前
|
JSON 算法 API
Python采集淘宝商品评论API接口及JSON数据返回全程指南
Python采集淘宝商品评论API接口及JSON数据返回全程指南
|
4月前
|
JSON API 数据安全/隐私保护
Python采集淘宝拍立淘按图搜索API接口及JSON数据返回全流程指南
通过以上流程,可实现淘宝拍立淘按图搜索的完整调用链路,并获取结构化的JSON商品数据,支撑电商比价、智能推荐等业务场景。
|
5月前
|
JSON 缓存 自然语言处理
多语言实时数据微店商品详情API:技术实现与JSON数据解析指南
通过以上技术实现与解析指南,开发者可高效构建支持多语言的实时商品详情系统,满足全球化电商场景需求。
|
4月前
|
JSON 中间件 Java
【GoGin】(3)Gin的数据渲染和中间件的使用:数据渲染、返回JSON、浅.JSON()源码、中间件、Next()方法
我们在正常注册中间件时,会打断原有的运行流程,但是你可以在中间件函数内部添加Next()方法,这样可以让原有的运行流程继续执行,当原有的运行流程结束后再回来执行中间件内部的内容。​ c.Writer.WriteHeaderNow()还会写入文本流中。可以看到使用next后,正常执行流程中并没有获得到中间件设置的值。接口还提供了一个可以修改ContentType的方法。判断了传入的状态码是否符合正确的状态码,并返回。在内部封装时,只是标注了不同的render类型。再看一下其他返回的类型;
256 3
|
4月前
|
JSON Java Go
【GoGin】(2)数据解析和绑定:结构体分析,包括JSON解析、form解析、URL解析,区分绑定的Bind方法
bind或bindXXX函数(后文中我们统一都叫bind函数)的作用就是将,以方便后续业务逻辑的处理。
344 3
|
5月前
|
JSON API 数据安全/隐私保护
Python采集淘宝评论API接口及JSON数据返回全流程指南
Python采集淘宝评论API接口及JSON数据返回全流程指南
|
5月前
|
JSON 自然语言处理 监控
淘宝关键词搜索与商品详情API接口(JSON数据返回)
通过商品ID(num_iid)获取商品全量信息,包括SKU规格、库存、促销活动、卖家信息、详情页HTML等。
|
5月前
|
JSON 自然语言处理 API
多语言实时数据淘宝商品评论API:技术实现与JSON数据解析指南
淘宝商品评论多语言实时采集需结合官方API与后处理技术实现。建议优先通过地域站点适配获取本地化评论,辅以机器翻译完成多语言转换。在合规前提下,企业可构建多语言评论数据库,支撑全球化市场分析与产品优化。
|
5月前
|
机器学习/深度学习 JSON API
干货,淘宝拍立淘按图搜索,淘宝API(json数据返回)
淘宝拍立淘按图搜索API接口基于深度学习与计算机视觉技术,通过解析用户上传的商品图片,在淘宝商品库中实现毫秒级相似商品匹配,并以JSON格式返回商品标题、图片链接、价格、销量、相似度评分等详细信息。

热门文章

最新文章