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 相关文章推荐
jquery使用animate方法实现控制元素移动
Mar 27 Javascript
牛叉的Jquery——Jquery与DOM对象的互相转换及DOM的三种操作
Oct 29 Javascript
尝试动手制作javascript放大镜效果
Dec 25 Javascript
如何使用headjs来管理和异步加载js
Nov 29 Javascript
关于javascript事件响应的基础语法总结(必看篇)
Dec 26 Javascript
javascript设计模式之单体模式学习笔记
Feb 15 Javascript
node.js-v6新版安装具体步骤(分享)
Sep 06 Javascript
vue中的router-view组件的使用教程
Oct 23 Javascript
如何实现iframe父子传参通信
Feb 05 Javascript
微信小程序 button样式设置为图片的方法
Jun 19 Javascript
Vue+Java 通过websocket实现服务器与客户端双向通信操作
Sep 22 Javascript
vue3如何优雅的实现移动端登录注册模块
Mar 29 Vue.js
基于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的一个完整SMTP类(解决邮件服务器需要验证时的问题)
2006/10/09 PHP
如何去掉文章里的 html 语法
2006/10/09 PHP
php中一个有意思的日期逻辑处理
2012/03/25 PHP
php实现留言板功能(代码详解)
2017/03/28 PHP
一个对于js this关键字的问题
2007/01/09 Javascript
一个简单的JavaScript数据缓存系统实现代码
2010/10/24 Javascript
jquery事件机制扩展插件 jquery鼠标右键事件。
2011/12/26 Javascript
通过jquery-ui中的sortable来实现拖拽排序的简单实例
2016/05/24 Javascript
window.open打开窗口被拦截的快速解决方法
2016/08/04 Javascript
JQuery动态添加Select的Option元素实现方法
2016/08/29 Javascript
简单易懂的天气插件(代码分享)
2017/02/04 Javascript
JavaScript通过改变文字透明度实现的文字闪烁效果实例
2017/04/27 Javascript
vue.js如何将echarts封装为组件一键使用详解
2017/10/10 Javascript
性能优化篇之Webpack构建速度优化的建议
2019/04/03 Javascript
[30:00]完美世界DOTA2联赛PWL S2 Rebirth vs LBZS 第二场 11.28
2020/12/01 DOTA
Python学习笔记之常用函数及说明
2014/05/23 Python
关于Python3 类方法、静态方法新解
2019/08/30 Python
PyCharm使用之配置SSH Interpreter的方法步骤
2019/12/26 Python
python GUI库图形界面开发之PyQt5开发环境配置与基础使用
2020/02/25 Python
pandas apply多线程实现代码
2020/08/17 Python
Django数据库迁移常见使用方法
2020/11/12 Python
python如何实现递归转非递归
2021/02/25 Python
canvas实现圆形进度条动画的示例代码
2017/12/26 HTML / CSS
泰国汽车、火车和轮渡票预订网站:Bus Online Ticket
2017/09/09 全球购物
Desigual英国官网:在线购买原创服装
2018/03/09 全球购物
Wedgwood英国官方网站:英式精致骨瓷餐具、礼品与生活精品,源于1759年
2019/09/02 全球购物
机关单位动员会主持词
2014/03/20 职场文书
2014年大学生四年规划书范文
2014/04/03 职场文书
父母对孩子的寄语
2014/04/09 职场文书
转让协议书范本
2014/04/15 职场文书
巾帼文明岗汇报材料
2014/12/24 职场文书
小学安全工作总结2015
2015/05/18 职场文书
婚庆司仪开场白
2015/05/29 职场文书
python文件名批量重命名脚本实例代码
2021/04/22 Python
java泛型通配符详解
2021/07/25 Java/Android
HTML页面点击按钮关闭页面的多种方式
2022/12/24 HTML / CSS