Jquery+Ajax+xml实现中国地区选择三级联动菜单效果(推荐)


Posted in jQuery onJune 09, 2017

本文主要介绍使用 Jquery+Ajax+xml,首先需要一个包含我国所有地图信息的xml文档。

此处选用的xml文档(共1000多行)主要结构如下:

<?xml version="1.0" encoding="utf-8"?>
<area Country="China">
 <province ID="1" provinceID="110000" province="北京市">
  <City CityID="110100" City="市辖区">
   <Piecearea PieceareaID="110101" Piecearea="东城区" />
   <Piecearea PieceareaID="110102" Piecearea="西城区" />
   <Piecearea PieceareaID="110103" Piecearea="崇文区" />
   <Piecearea PieceareaID="110104" Piecearea="宣武区" />
   <Piecearea PieceareaID="110105" Piecearea="朝阳区" />
   <Piecearea PieceareaID="110106" Piecearea="丰台区" />
   <Piecearea PieceareaID="110107" Piecearea="石景山区" />
   <Piecearea PieceareaID="110108" Piecearea="海淀区" />
   <Piecearea PieceareaID="110109" Piecearea="门头沟区" />
   <Piecearea PieceareaID="110111" Piecearea="房山区" />
   <Piecearea PieceareaID="110112" Piecearea="通州区" />
   <Piecearea PieceareaID="110113" Piecearea="顺义区" />
   <Piecearea PieceareaID="110114" Piecearea="昌平区" />
   <Piecearea PieceareaID="110115" Piecearea="大兴区" />
   <Piecearea PieceareaID="110116" Piecearea="怀柔区" />
   <Piecearea PieceareaID="110117" Piecearea="平谷区" />
  </City>
<province>

制作对应的表单,根据设置选择省/市的动作:

<h2>地区三级联动菜单</h2>
  省:<select id="province" onchange="showcity()"><option value="0">-请选择-</option></select>
  市:<select id="city" onchange="showdistrict()"><option value="0">-请选择-</option></select>
  地区:<select id="district"><option value="0">-请选择-</option></select>

以下是JS代码行

//声明一个全局变量,用于存储第一次请求的xml信息,避免后续多次频繁请求xml
    var xmldom =null;
    //获取并显示省份信息
    function showprovince(){
      //使用ajax去服务器获得xml文件里面的省份信息
      $.ajax({
        url:'./ChinaArea.xml',
        //data:
        dataType:'xml',//相当于调用responseXML
        type:'get',
        success:function(msg){
          //将返回的xml信息赋予xmldom
          xmldom = msg;
          //获得province 元素节点对象
          var prov = $(msg).find('province');
          //遍历省份信息
          prov.each(function(k,v){
            var nm = $(this).attr('province');
            var id = $(this).attr('provinceID');
            //追加到指定的节点
            $('#province').append("<option value="+id+">"+nm+"</option>");
          });
        }

      });
    }
    //网页加载显示省份信息  
    $(function(){
      showprovince();
    });
    function showcity(){
      //获取 省份 的id
      var pid = $('#province option:selected').val();
      //根据xmldom信息 找到指定的省份节点
      var xml_province = $(xmldom).find('province[provinceID='+pid+']');
      // 获取对应所有县市节点
      var city = $(xml_province).find('City');
      //在遍历追加前,先清空此前已经显示的信息
      $('#city').empty();
      $('#city').append('<option value="0">-请选择-</option>');
      //遍历追加县市
      city.each(function(k,v){
        var nm = $(this).attr('City');
        var id = $(this).attr('CityID');
        $('#city').append('<option value='+id+'>'+nm+'</option>');
      });
    }
    //以下函数的逻辑与showcity()的逻辑一致
    function showdistrict(){
      //获取 县市 的id
      var cid = $('#city option:selected').val();
      //根据xmldom信息 找到指定的县市节点
      var xml_city = $(xmldom).find('City[CityID='+cid+']');
      // 获取对应所有地区节点
      var district = $(xml_city).find('Piecearea');
      $('#district').empty();
      $('#district').append('<option value="0">-请选择-</option>');
      district.each(function(k,v){
        var nm = $(this).attr('Piecearea');
        var id = $(this).attr('PieceareaID');
        $('#district').append('<option value='+id+'>'+nm+'</option>');
      });
    }

以上这篇Jquery+Ajax+xml实现中国地区选择三级联动菜单效果(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

jQuery 相关文章推荐
jquery ui sortable拖拽后保存位置
Apr 27 jQuery
jQuery表单验证之密码确认
May 22 jQuery
Vue.js列表渲染绑定jQuery插件的正确姿势
Jun 29 jQuery
jQuery列表检索功能实现代码
Jul 17 jQuery
jQuery实现的自定义轮播图功能详解
Dec 28 jQuery
jQuery实现的卷帘门滑入滑出效果【案例】
Feb 18 jQuery
jquery中为什么能用$操作
Jun 18 jQuery
jQuery位置选择器用法实例分析
Jun 28 jQuery
9种方法优化jQuery代码详解
Feb 04 jQuery
jquery实现手风琴案例
May 04 jQuery
原生jQuery实现只显示年份下拉框
Dec 24 jQuery
jQuery冲突问题解决方法
Jan 19 jQuery
jQuery Validate表单验证插件实现代码
Jun 08 #jQuery
jquery Ajax实现Select动态添加数据
Jun 08 #jQuery
jquery实现放大镜简洁代码(推荐)
Jun 08 #jQuery
jQuery+ajax实现局部刷新的两种方法
Jun 08 #jQuery
jQuery 添加样式属性的优先级别方法(推荐)
Jun 08 #jQuery
jquery dataTable 后台加载数据并分页实例代码
Jun 07 #jQuery
jQuery用户头像裁剪插件cropbox.js使用详解
Jun 07 #jQuery
You might like
DC宇宙的第一个英雄,堪称动漫史鼻祖,如今成为美国文化的象征
2020/04/09 欧美动漫
允许phpmyadmin空密码登录的配置方法
2011/05/29 PHP
PHP中常用的转义函数
2014/02/28 PHP
PHP编写daemon process详解及实例代码
2016/09/30 PHP
用htc组件制作windows选项卡
2007/01/13 Javascript
用jQuery模拟页面加载进度条的实现代码
2011/12/19 Javascript
jquery实现手风琴效果实例代码
2013/11/15 Javascript
js 跳出页面的frameset框架示例介绍
2013/12/23 Javascript
jquery判断input值不为空的方法
2016/06/05 Javascript
原生JavaScript制作计算器
2016/10/16 Javascript
jQuery和JavaScript节点插入元素的方法对比
2016/11/18 Javascript
js时间控件只显示年月
2017/01/08 Javascript
jQuery实现拖拽可编辑模块功能代码
2017/01/12 Javascript
原生js+cookie实现购物车功能的方法分析
2017/12/21 Javascript
详解写好JS条件语句的5条守则
2019/02/28 Javascript
js实现坦克移动小游戏
2019/10/28 Javascript
解决vue elementUI中table里数字、字母、中文混合排序问题
2020/01/07 Javascript
基于JS实现操作成功之后自动跳转页面
2020/09/25 Javascript
Python将DataFrame的某一列作为index的方法
2018/04/08 Python
python中csv文件的若干读写方法小结
2018/07/04 Python
Python爬虫常用小技巧之设置代理IP
2018/09/13 Python
python dict 相同key 合并value的实例
2019/01/21 Python
Python3多线程基础知识点
2019/02/19 Python
pyhanlp安装介绍和简单应用
2019/02/22 Python
django项目环境搭建及在虚拟机本地创建django项目的教程
2019/08/02 Python
基于selenium及python实现下拉选项定位select
2020/07/22 Python
如何利用python生成MD5并去重
2020/12/07 Python
会计实习自我鉴定
2013/12/04 职场文书
大学同学聚会邀请函
2014/01/19 职场文书
《跨越海峡的生命桥》教学反思
2014/02/24 职场文书
资金主管岗位职责范本
2014/03/04 职场文书
道路施工安全责任书
2014/07/24 职场文书
2016优秀毕业生个人事迹材料
2016/02/29 职场文书
大学学生会主席竞选稿怎么写?
2019/08/19 职场文书
Prometheus 监控MySQL使用grafana展示
2021/08/30 MySQL
python数字图像处理实现图像的形变与缩放
2022/06/28 Python