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插件HighCharts绘制简单2D折线图效果示例【附demo源码】
Mar 21 jQuery
JS jQuery使用正则表达式去空字符的简单实现代码
May 20 jQuery
jQuery模拟实现天猫购物车动画效果实例代码
May 25 jQuery
Jquery中attr与prop的区别详解
May 27 jQuery
jQuery图片缩放插件smartZoom使用实例详解
Aug 25 jQuery
jquery学习笔记之无new构建详解
Dec 07 jQuery
jQuery+koa2实现简单的Ajax请求的示例
Mar 06 jQuery
jQuery实现动态加载select下拉列表项功能示例
May 31 jQuery
jquery 动态遍历select 赋值的实例
Sep 12 jQuery
JQuery样式操作、click事件以及索引值-选项卡应用示例
May 14 jQuery
jquery实现直播视频弹幕效果
Feb 25 jQuery
jQuery实现简单飞机大战
Jul 05 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
帅气的琦玉老师
2020/03/02 日漫
Excel数据导入Mysql数据库的实现代码
2008/06/05 PHP
关于PHP递归算法和应用方法介绍
2013/04/15 PHP
PHP Streams(流)详细介绍及使用
2015/05/12 PHP
Yii2.0实现生成二维码功能实例
2017/10/24 PHP
学习thinkphp5.0验证类使用方法
2017/11/16 PHP
javascript attachEvent和addEventListener使用方法
2009/03/19 Javascript
Mootools 1.2 手风琴(Accordion)教程
2009/09/15 Javascript
网络图片延迟加载实现代码 超越jquery控件
2010/03/27 Javascript
jquery获取ASP.NET服务器端控件dropdownlist和radiobuttonlist生成客户端HTML标签后的value和text值
2010/06/28 Javascript
angularJS 入门基础
2015/02/09 Javascript
jquery+html5制作超酷的圆盘时钟表
2015/04/14 Javascript
text-align:justify实现文本两端对齐 兼容IE
2015/08/19 Javascript
再谈JavaScript异步编程
2016/01/27 Javascript
jQuery实现鼠标经过显示动画边框特效
2017/03/24 jQuery
Angular6笔记之封装http的示例代码
2018/07/27 Javascript
详解微信小程序与内嵌网页交互实现支付功能
2018/10/22 Javascript
微信小程序实现的日期午别医生排班表功能示例
2019/01/09 Javascript
微信小程序HTTP请求从0到1封装
2019/09/09 Javascript
[36:20]KG vs SECRET 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/19 DOTA
python发送邮件接收邮件示例分享
2014/01/21 Python
Python自动发邮件脚本
2017/03/31 Python
基于python socketserver框架全面解析
2017/09/21 Python
tensorflow实现KNN识别MNIST
2018/03/12 Python
Django 多语言教程的实现(i18n)
2018/07/07 Python
Linux下安装python3.6和第三方库的教程详解
2018/11/09 Python
python 使用cx-freeze打包程序的实现
2020/03/14 Python
python中前缀运算符 *和 **的用法示例详解
2020/05/28 Python
python调用有道智云API实现文件批量翻译
2020/10/10 Python
python3爬虫中多线程的优势总结
2020/11/24 Python
秋季运动会活动方案
2014/02/05 职场文书
社区综治宣传月活动总结
2014/07/02 职场文书
小学教师暑期培训方案
2014/08/28 职场文书
党员学习党的群众路线思想汇报(5篇)
2014/09/10 职场文书
努力工作保证书
2015/02/28 职场文书
素质教育培训心得体会
2016/01/19 职场文书