JavaScript实现的级联算法示例【省市二级联动功能】


Posted in Javascript onDecember 25, 2018

本文实例讲述了JavaScript实现的级联算法。分享给大家供大家参考,具体如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>LinkDemo</title>
    <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
    </script>
    <script type="text/javascript">
      var shengshiString = "1_山东省-11_德州市+12_青岛市+13_济南市~2_河北省-21_邯郸市*211_临漳县/212_磁县+22_石家庄市*221_定县/222_宁县+23_保定市";
      $(document).ready(function(){
        init();
      });
      function init(){
        var shengArray = shengshiString.split("~");
        for (var i = 0; i < shengArray.length; i++) {
          var sheng = shengArray[i].split("-")[0];
          var shi = shengArray[i].split("-")[1];
          var shengid = sheng.split("_")[0];
          var shengName = sheng.split("_")[1];
          var Newoption = $("<option></option>");
          $(Newoption).val(shengid);
          $(Newoption).text(shengName);
          $("#sheng").append(Newoption);
          if (i == 0) {
            shengchange(shengid);
          }
        }
      }
      function shengchange(shengidparam){
        $("#shi").empty();
        var shengArray = shengshiString.split("~");
        for (var i = 0; i < shengArray.length; i++) {
          var shengString = shengArray[i].split("-")[0];
          var shiString = shengArray[i].split("-")[1];
          var shengId = shengString.split("_")[0];
          if (shengidparam == shengId) {
            var shiArray = shiString.split("+");
            for (var j = 0; j < shiArray.length; j++) {
              var shistring = shiArray[j].split("*")[0];
              var shi = shistring;
              var shiId = shi.split("_")[0];
              var shiName = shi.split("_")[1];
              var Newoption = $("<option></option>");
              $(Newoption).val(shiId);
              $(Newoption).text(shiName);
              $("#shi").append(Newoption);
              if (shiName == "邯郸市" || shiName == "石家庄市") {
                shichange(shiId);
              }
            }
          }
        }
      }
      function shichange(shiidparam){
        $("#xian").empty();
        var shengArray = shengshiString.split("~");
        for (var i = 0; i < shengArray.length; i++) {
          var shengString = shengArray[i].split("-")[0];
          var shiString = shengArray[i].split("-")[1];
          var shengId = shengString.split("_")[0];
          var shiArray = shiString.split("+");
          for (var j = 0; j < shiArray.length; j++) {
            var shistring = shiArray[j].split("*")[0];
            var xianarray = shiArray[j].split("*")[1];
            var shi = shistring;
            var shiId = shi.split("_")[0];
            var shiName = shi.split("_")[1];
            if (shiId == shiidparam) {
              var xian = xianarray.split("/");
              for (var s = 0; s < xian.length; s++) {
                var xianId = xian[s].split("_")[0];
                var xianName = xian[s].split("_")[1];
                var Newoption = $("<option></option>");
                $(Newoption).val(xianId);
                $(Newoption).text(xianName);
                $("#xian").append(Newoption);
              }
            }
          }
        }
      }
    </script>
  </head>
  <body>
    <select id="sheng" onchange="shengchange(this.value)">
    </select>
    <select id="shi" onchange="shichange(this.value)">
    </select>
    <select id="xian">
    </select>
  </body>
</html>

使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码,运行效果如下图所示:

JavaScript实现的级联算法示例【省市二级联动功能】

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
javascript qq右下角滑出窗口 sheyMsg
Mar 21 Javascript
js获取字符串最后一位方法汇总
Nov 13 Javascript
JavaScript中SetInterval与setTimeout的用法详解
Nov 10 Javascript
使用jQuery实现WordPress中的Ctrl+Enter和@评论回复
May 21 Javascript
Angular2利用组件与指令实现图片轮播组件
Mar 27 Javascript
通过js动态创建标签,并设置属性方法
Feb 24 Javascript
浅析node应用的timing-attack安全漏洞
Feb 28 Javascript
用element的upload组件实现多图片上传和压缩的示例代码
Feb 12 Javascript
js实现继承的方法及优缺点总结
May 08 Javascript
使用Bootstrap做一个朝代历史表
Dec 10 Javascript
js中位数不足自动补位扩展padLeft、padRight实现代码
Apr 06 Javascript
js轮播图之旋转木马效果
Oct 13 Javascript
详解vuex commit保存数据技巧
Dec 25 #Javascript
bootstrap table实现合并单元格效果
Dec 24 #Javascript
Electron autoUpdater实现Windows安装包自动更新的方法
Dec 24 #Javascript
Windows下支持自动更新的Electron应用脚手架的方法
Dec 24 #Javascript
如何使用electron-builder及electron-updater给项目配置自动更新
Dec 24 #Javascript
Vue.js组件高级特性实例详解
Dec 24 #Javascript
JavaScript模板引擎原理与用法详解
Dec 24 #Javascript
You might like
简单谈谈php中的unicode和utf8编码
2015/06/10 PHP
php中session定期自动清理的方法
2015/11/12 PHP
javascript import css实例代码
2008/07/18 Javascript
javascript 禁用IE工具栏,导航栏等等实现代码
2013/04/01 Javascript
JS解析XML实例分析
2015/01/30 Javascript
jquery滚动加载数据的方法
2015/03/09 Javascript
jQuery+jRange实现滑动选取数值范围特效
2015/03/14 Javascript
jquery实现点击label的同时触发文本框点击事件的方法
2015/06/05 Javascript
JQuery实现Ajax加载图片的方法
2015/12/24 Javascript
如何使用jquery修改css中带有!important的样式属性
2016/04/28 Javascript
深入剖析JavaScript中的函数currying柯里化
2016/04/29 Javascript
JavaScript 详解预编译原理
2017/01/22 Javascript
JS创建Tag标签的方法详解
2017/06/09 Javascript
webpack开发环境和生产环境的深入理解
2018/11/08 Javascript
微信小程序的引导页实现代码
2020/06/24 Javascript
详解微信小程序动画Animation执行过程
2020/09/23 Javascript
详解vue中使用transition和animation的实例代码
2020/12/12 Vue.js
python基础教程之面向对象的一些概念
2014/08/29 Python
详解Golang 与python中的字符串反转
2017/07/21 Python
Sublime开发python程序的示例代码
2018/01/24 Python
python如何创建TCP服务端和客户端
2018/08/26 Python
python自定义函数实现一个数的三次方计算方法
2019/01/20 Python
使用Python实现企业微信的自动打卡功能
2019/04/30 Python
python BlockingScheduler定时任务及其他方式的实现
2019/09/19 Python
python 实现从高分辨图像上抠取图像块
2020/01/02 Python
Python3 元组tuple入门基础
2020/02/09 Python
python中random.randint和random.randrange的区别详解
2020/09/20 Python
实现CSS3中的border-radius(边框圆角)示例代码
2013/07/19 HTML / CSS
可靠的数据流传输TCP
2016/03/15 面试题
岗位竞聘书范文
2014/03/31 职场文书
2015秋季幼儿园开学寄语
2015/03/25 职场文书
导游词之秦始皇兵马俑博物馆
2019/09/29 职场文书
Nginx本地目录映射实现代码实例
2021/03/31 Servers
用javascript制作qq注册动态页面
2021/04/14 Javascript
Python代码,能玩30多款童年游戏!这些有几个是你玩过的
2021/04/27 Python
Java实现简单小画板
2022/06/10 Java/Android