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插件FusionWidgets实现的Cylinder图效果示例【附demo源码】
Mar 23 jQuery
jQuery 添加样式属性的优先级别方法(推荐)
Jun 08 jQuery
利用jQuery异步上传文件的插件用法详解
Jul 19 jQuery
解决JQuery全选/反选第二次失效的问题
Oct 11 jQuery
基于jQuery.i18n实现web前端的国际化
May 04 jQuery
jQuery实现的点击按钮改变样式功能示例
Jul 21 jQuery
jQuery实现的简单日历组件定义与用法示例
Dec 24 jQuery
jQuery使用$.extend(true,object1, object2);实现深拷贝对象的方法分析
Mar 06 jQuery
jquery+php后台实现省市区联动功能示例
May 23 jQuery
JQuery实现ul中添加LI和删除指定的Li元素功能完整示例
Oct 16 jQuery
jQuery实现滑动星星评分效果(每日分享)
Nov 13 jQuery
jQuery实现简单全选框
Sep 13 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
php过滤XSS攻击的函数
2013/11/12 PHP
php配合jquery实现增删操作具体实例
2013/12/12 PHP
PHP中用Trait封装单例模式的实现
2019/12/18 PHP
一个关于javascript匿名函数的问题分析
2012/03/30 Javascript
使用jquery hover事件实现表格的隔行换色功能示例
2013/09/03 Javascript
13 款最热门的 jQuery 图像 360 度旋转插件推荐
2014/12/09 Javascript
jQuery+json实现的简易Ajax调用实例
2015/12/14 Javascript
JavaScript 不支持 indexof 该如何解决
2016/03/30 Javascript
JavaScript 深层克隆对象详解及实例
2016/11/03 Javascript
vuejs响应用户事件(如点击事件)
2017/03/14 Javascript
web.js.字符串与正则表达式操作
2017/05/13 Javascript
深入理解基于vue-cli的vuex配置
2017/07/24 Javascript
基于vue.js路由参数的实例讲解——简单易懂
2017/09/07 Javascript
微信小程序简单实现form表单获取输入数据功能示例
2017/11/30 Javascript
JS设计模式之访问者模式定义与用法分析
2018/02/05 Javascript
scrapy自定义pipeline类实现将采集数据保存到mongodb的方法
2015/04/16 Python
Python基于hashlib模块的文件MD5一致性加密验证示例
2018/02/10 Python
django框架使用orm实现批量更新数据的方法
2019/06/21 Python
python tkinter窗口最大化的实现
2019/07/15 Python
pycharm 中mark directory as exclude的用法详解
2020/02/14 Python
如何在Python 游戏中模拟引力
2020/03/27 Python
阿根廷票务网站:StubHub阿根廷
2018/04/13 全球购物
比较一下entity bean和session bean
2013/12/27 面试题
城市轨道专业个人求职信范文
2013/09/23 职场文书
集团公司总经理岗位职责
2013/12/20 职场文书
创业计划书撰写原则
2014/01/25 职场文书
文明宿舍获奖感言
2014/02/07 职场文书
《望洞庭》教学反思
2014/02/16 职场文书
财务人员担保书
2014/05/13 职场文书
大学专科求职信
2014/07/02 职场文书
简易离婚协议书范本2014
2014/10/15 职场文书
2015年父亲节寄语
2015/03/23 职场文书
七年级之开学家长寄语35句
2019/09/05 职场文书
导游词之南京中山陵
2019/11/27 职场文书
Java并发编程之Executor接口的使用
2021/06/21 Java/Android
vue实现移动端div拖动效果
2022/03/03 Vue.js