经常碰到这样的需求,如省市_城市_乡镇下拉框。后一个下拉框的内容会根据前一个的改变而改变,之前的解决方法往往是在前一个改变的时候,向后台发送请求临时获取对应的内容。这样每触发一次就会网络请求一次,这种方法显然不甚合理,下面使用下拉js实现的联动下拉框,只需要在页面加载的时候将数据准备好,根据数据key值的巧妙设置来实现联动。

联动下拉框的html代码

<!DOCTYPE html>
<html lang="zh_CN">
<head>
<meta charset="UTF-8">
<title>下拉框联动效果</title>
<script src="js/mySelects.js"></script>
</head>
<body>
<div id="div1"></div>
</body>
</html>

联动下拉框html代码

联动下拉框的js代码

document.addEventListener('DOMContentLoaded',function(){
console.log('domContentLoaded');
var mySels=new Sels({'id':'div1','level':''});
//第一级下拉框的数据
mySels.add('',['','','']);
//第二级下拉框的数据,1_i对应第一级下拉框第i个选中项
mySels.add('1_1',['1_1','1_2','1_3']);
mySels.add('1_2',['2_1','2_2','2_3']);
mySels.add('1_3',['3_1','3_2','3_3']);
//第三级下拉框的数据,1_i_j对应第一级下拉框第i个选中项,第二级下拉框第j个选中项的数据
mySels.add('1_1_1',['1_1_1','1_1_2','1_1_3']);
mySels.add('1_1_2',['1_2_1','1_2_2','1_2_3']);
mySels.add('1_1_3',['1_3_1','1_3_2','1_3_3']);
mySels.add('1_2_1',['2_1_1','2_1_2','2_1_3']);
mySels.add('1_2_2',['2_2_1','2_2_2','2_2_3']);
mySels.add('1_2_3',['2_3_1','2_3_2','2_3_3']);
mySels.add('1_3_1',['3_1_1','3_1_2','3_1_3']);
mySels.add('1_3_2',['3_2_1','3_2_2','3_2_3']);
mySels.add('1_3_3',['3_3_1','3_3_2','3_3_3']);
mySels.init(this.level);
},false); //联动下拉菜单对应的类,level代表多少级下拉菜单
function extendOptions(oldOpt,newOpt){
//如果没有就添加,如果有就替换
for(var key in newOpt){
oldOpt[key]=newOpt[key];
}
}
/**
*option 构造联动下拉菜单的初始化参数,其中以下两项是必须的:
*id:联动下拉菜单父元素的id
*level:联动下拉菜单包含几级下拉菜单
*/
function Sels(option){
extendOptions(this,option);
this.oParent=document.getElementById(this.id);
this.data={};
//构造函数没有执行完,对象还未创建,因此不能调用相关函数?
this.selects=this.oParent.getElementsByTagName('select');
} Sels.prototype={
constructor:Sels,
add:function(key,value){
this.data[key]=value;
},
init:function(level){
var that=this;
for(var i=;i<=this.level;i++){
var oSel=document.createElement('select');
var oOpt=new Option('默认','默认');
oSel.add(oOpt,undefined);
oSel.index=i;
//为其指定change事件 oSel.addEventListener('change',function(){
//内部函数的this指向的是当前的select对象
that.change(this.index);
},false);
this.oParent.appendChild(oSel);
} //为第一个下拉框添加选项
var arr=this.data[''];
for(i=,len=arr.length;i<len;i++){
oOpt=new Option(arr[i],arr[i]);
this.selects[].add(oOpt,undefined);
} },
//index代表当前发生change事件是在第几级下拉框,其后的下拉框需要对该事件做出相应
change:function(index){
var str='';
for(var i=;i<index;i++){
str+='_'+this.selects[i].options.selectedIndex;
}
if(this.data[str]){
this.selects[index].options.length=;
var arr=this.data[str];
for(var i=;i<arr.length;i++){
var oOpt=new Option(arr[i],arr[i]);
this.selects[index].add(oOpt,undefined);
}
this.selects[index].options[].selected=true;
//之后的一次联动
index++;
if(index<this.selects.length){
this.change(index);
}
}else{
//说明选择的是默认
//此时,将后面的选项都仅保留“默认”这一项即可
for(var i=index;i<this.selects.length;i++){
this.selects[i].options.length=;
} }
},
};

联动下拉框js代码

相关知识点整理:

1.利用data的key值来实现联动

2.面向对象的思路

javascript实例学习之一——联动下拉框的更多相关文章

  1. ajax 多级联动 下拉框 Demo

    写了ajax实现级联下拉框,考虑常用,并且级联个数随不同业务个数不同,于是就整理了一下,实现了 ajax + N级联动 下拉框的效果 效果图 HTML 代码 <h2> 省级联动</h ...

  2. Vue.js组件之联动下拉框

    Html代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  3. SharePoint 2013 使用查阅项实现联动下拉框

    SharePoint列表使用中,经常会用到下拉框,而有些特殊的需求,会用到联动的下拉框,在SharePoint中默认没有这样的字段,所以如果实现,我们需要自己想办法. 这里,我们介绍如何使用JQuer ...

  4. Web 1三级联动 下拉框 2添加修改删除 弹框

    Web  三级联动 下拉框 using System; using System.Collections.Generic; using System.Linq; using System.Web; u ...

  5. JS年月日三级联动下拉框日期选择代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. jQuery实现的3个基础案例(仿QQ列表分组,二级联动下拉框,模拟员工信息管理系统)

    1.仿QQ列表分组 <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type&quo ...

  7. 项目总结01:JSP mysql SpringMvc下中国省市县三级联动下拉框

    JSP mysql SpringMvc下中国省市县三级联动下拉框 关键词 JSP  mysql数据库  SpringMvc  ajax   Controller层  Service层  中国地区  省 ...

  8. Android实现三级联动下拉框 下拉列表spinner

    Android实现(省.市.县)三级联动下拉框 下拉列表spinner 转载请注明出处: http://www.goteny.com/articles/2013/11/46.html http://w ...

  9. jquery+html三级联动下拉框

    jquery+html三级联动下拉框及详情页面加载时的select初始化问题   html写的三个下拉框,如下: <select name="ddlQYWZYJ" id=&q ...

随机推荐

  1. 【转】SVN环境搭建教程

    http://www.cnblogs.com/xiaobaihome/archive/2012/03/20/2407610.html http://www.cnblogs.com/xiaobaihom ...

  2. Apache Spark技术实战之1 -- KafkaWordCount

    欢迎转载,转载请注明出处,徽沪一郎. 概要 Spark应用开发实践性非常强,很多时候可能都会将时间花费在环境的搭建和运行上,如果有一个比较好的指导将会大大的缩短应用开发流程.Spark Streami ...

  3. The P4 Language Specification v1.0.2 Header and Fields

    前言 本文参考P4.org网站给出的<The P4 Language Specification v1.0.2>的第二部分首部及字段,仅供学习:). 欢迎交流! Header and Fi ...

  4. Thinkphp 不显示生成的验证码 【转载】

    在调用验证码之前加上 ob_clean(); 不显示验证码的代码: public function verify(){ $verify = new \Think\Verify(); $verify-& ...

  5. UDP 构建p2p打洞过程的实现原理(持续更新)

    UDP 构建p2p打洞过程的实现原理(持续更新) 发表于7个月前(2015-01-19 10:55)   阅读(433) | 评论(0) 8人收藏此文章, 我要收藏 赞0 8月22日珠海 OSC 源创 ...

  6. cPanel设置自定义404错误页

    利用这个cpanel的错误页工具,你就可以定制错误页面了.设置自定义404错误页,有两种简单的方法. 一,利用cpanel后台控制面板添加设置404自定义错误页的方法 步骤       1.登录cPa ...

  7. 不绑架输入--document.getElementById("linkage_"+id_type+"_echo").value="";--联动

    <script> function w_linkage(id_type) { var selected = $("#linkage_"+id_type+"_t ...

  8. jdbc 日期时间相关的类型

    jdbc 日期时间相关的类型 1.sql.Date sql包中的日期类Date是util包中Date类的子类,实际上也是util.Date类的子集.它只处理年月日,而忽略小时和分秒,用以代表SQL的D ...

  9. java 形参实参

    java方法中传值和传引用的问题是个基本问题,但是也有很多人一时弄不清. (一)基本数据类型:传值,方法不会改变实参的值. public class TestFun { public static v ...

  10. 【转】 Update和FixedUpdate的区别

    MonoBehaviour.Update 更新 当MonoBehaviour启用时,其Update在每一帧被调用. MonoBehaviour.FixedUpdate 固定更新 当MonoBehavi ...