js select下拉联动 更具级联性!


Posted in Javascript onApril 17, 2020

之前有过记录,select下拉联动 (Bootstrap、JQuery插件之cxselect)区别在这个级联性更强。

js select下拉联动 更具级联性!

HTML源码:

<!DOCTYPE html> 
<head> 
 <meta charset="utf-8"> 
 <title></title> 
</head> 
<script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script> 
<script type="text/javascript" src="USjs.js"></script> 
<body> 
 
<div class="container"> 
 <table> 
 <tr> 
  <td>厂商:</td> 
  <td><select id="selF"><option>请选择</option></select></td> 
  <td>品牌:</td> 
  <td><select id="selT"><option>请选择</option></select></td> 
  <td>型号:</td> 
  <td><select id="selC"><option>请选择</option></select></td> 
  <td><input type="button" value="查询" id="Button1" class="btn" /></td> 
 </tr> 
 </table> 
</div> 
 
</body> 
</html>

JS(USjs.js)源码: 在转载的基础上做了修改,特别是源数据JSON格式。

$(function(){ 
 
 function objInit(obj){ 
 return $(obj).html('<option>请选择</option>'); 
 } 
 
 $.getJSON('data.json', function(json) { 
 var arrData = json; 
 $.each(arrData,function(pF,pV){ 
  $('#selF').append('<option value="'+pF+'">'+pV.n+'</option>'); 
 }); 
 $('#selF').change(function(){ 
  objInit('#selT'); 
  objInit('#selC'); 
  $.each(arrData,function(pF,pS){ 
  if($('#selF option:selected').attr('value')==pF){ 
   $.each(pS.s,function(pT,pC){ 
   $('#selT').append('<option value="'+pT+'">'+pC.n+'</option>'); 
   }); 
   $('#selT').change(function(){ 
   objInit('#selC'); 
   $.each(pS.s,function(pT,pC){ 
    if($('#selT option:selected').attr('value')==pT){ 
    $.each(pC.s,function(ii,vv){ 
     $('#selC').append('<option value="'+ii+'">'+vv.n+'</option>'); 
    }) 
    } 
   }) 
   }); 
  } 
  }) 
 }); 
 }); //getJSON 
});

JSON(data.json)文件

[ 
 { 
 "n":"厂商1", 
 "s":[ 
  { 
  "n":"品牌一", 
  "s":[{"n":"型号1-1-1"},{"n":"型号1-1-2"}] 
  }, 
  { 
  "n":"品牌二", 
  "s":[{"n":"型号1-2-1"},{"n":"型号1-2-2"}] 
  } 
  ] 
 }, 
 { 
 "n":"厂商2", 
 "s":[ 
  { 
  "n":"品牌一", 
  "s":[{"n":"型号2-1-1"},{"n":"型号2-1-2"}] 
  }, 
  { 
  "n":"品牌二", 
  "s":[{"n":"型号2-2-1"},{"n":"型号2-2-2"}] 
  } 
  ] 
 }, 
 { 
 "n":"厂商3", 
 "s":[ 
  { 
  "n":"品牌一", 
  "s":[{"n":"型号3-1-1"},{"n":"型号3-1-2"}] 
  }, 
  { 
  "n":"品牌二", 
  "s":[{"n":"型号3-2-1"},{"n":"型号3-2-2"}] 
  } 
  ] 
 } 
]

Find more from: //3water.com/article/102040.htm

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
用js得到网页中所有的div的id
Oct 19 Javascript
JavaScript中按位“异或”运算符使用介绍
Mar 14 Javascript
jQuery插件分享之分页插件jqPagination
Jun 06 Javascript
jQuery+CSS3实现四种应用广泛的导航条制作实例详解
Sep 17 Javascript
js中获取键盘事件的简单实现方法
Oct 10 Javascript
利用js定义一个导航条菜单
Mar 14 Javascript
Angular2实现自定义双向绑定属性
Mar 22 Javascript
angular ng-model 无法获取值的处理方法
Oct 02 Javascript
webpack dll打包重复问题优化的解决
Oct 10 Javascript
vue.js的简单自动求和计算实例
Nov 08 Javascript
微信小程序日历插件代码实例
Dec 04 Javascript
10分钟学会js处理json的常用方法
Dec 06 Javascript
基于JavaScript实现熔岩灯效果导航菜单
Jan 04 #Javascript
使用Javascript判断浏览器终端设备(PC、IOS(iphone)、Android)
Jan 04 #Javascript
jquery+ajax实现省市区三级联动效果简单示例
Jan 04 #Javascript
基于jQuery实现火焰灯效果导航菜单
Jan 04 #Javascript
深入理解Javascript中的valueOf与toString
Jan 04 #Javascript
使用UrlConnection实现后台模拟http请求的简单实例
Jan 04 #Javascript
js实现定时进度条完成后切换图片
Jan 04 #Javascript
You might like
php生成EAN_13标准条形码实例
2013/11/13 PHP
php数据库备份还原类分享
2014/03/20 PHP
php实现中文字符截取防乱码方法汇总
2015/04/29 PHP
textContent在Firefox下与innerText等效的属性
2007/05/12 Javascript
window.location和document.location的区别分析
2008/12/23 Javascript
Ext javascript建立超链接,进行事件处理的实现方法
2009/03/22 Javascript
jQuery EasyUI API 中文文档 DateTimeBox日期时间框
2011/10/16 Javascript
多选列表框动态添加,移动,删除,全选等操作的简单实例
2014/01/13 Javascript
js编写一个简单的产品放大效果代码
2016/06/27 Javascript
Kendo Grid editing 自定义验证报错提示的解决方法
2016/11/18 Javascript
JavaScript中for循环的几种写法与效率总结
2017/02/03 Javascript
canvas实现十二星座星空图
2017/02/14 Javascript
Javascript面试经典套路reduce函数查重
2017/03/23 Javascript
node.js+captchapng+jsonwebtoken实现登录验证示例
2017/08/17 Javascript
js实现鼠标跟随运动效果
2020/08/02 Javascript
微信小程序在其他页面监听globalData中值的变化
2019/07/15 Javascript
浅析 Vue 3.0 的组装式 API(一)
2020/08/31 Javascript
Python的Django框架下管理站点的基本方法
2015/07/17 Python
PyQt5每天必学之带有标签的复选框
2018/04/19 Python
python+pyqt5编写md5生成器
2019/03/18 Python
python多线程抽象编程模型详解
2019/03/20 Python
Python玩转PDF的各种骚操作
2019/05/06 Python
Python button选取本地图片并显示的实例
2019/06/13 Python
对python中不同模块(函数、类、变量)的调用详解
2019/07/16 Python
python PIL和CV对 图片的读取,显示,裁剪,保存实现方法
2019/08/07 Python
python3.6生成器yield用法实例分析
2019/08/23 Python
Python实现把类当做字典来访问
2019/12/16 Python
python机器学习库xgboost的使用
2020/01/20 Python
Pycharm 使用 Pipenv 新建的虚拟环境(图文详解)
2020/04/16 Python
HTML5中form如何关闭自动完成功能的方法
2018/07/02 HTML / CSS
美术专业个人自我评价
2014/01/18 职场文书
装饰公司活动策划方案
2014/08/23 职场文书
课程设计的心得体会
2014/09/03 职场文书
幼儿园教师师德承诺书
2015/04/28 职场文书
毕业论文指导老师意见
2015/06/04 职场文书
3招让你摆脱即兴讲话冷场尴尬
2019/08/08 职场文书