js 联动下拉菜单
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>js 联动下拉菜单</title>
<script>
window.onload=function()
{
var s1=new Sel('div1');
// 数据
s1.add('0',['1','2','3']);
s1.add('0_0',['1_1','1_2','1_3']);
s1.add('0_0_0',['1_1_1','1_1_2','1_1_3']);
s1.add('0_0_1',['1_2_1','1_2_2','1_2_3']);
s1.add('0_0_2',['1_3_1','1_3_2','1_3_3']);
s1.add('0_1',['2_1','2_2','2_3']);
s1.add('0_1_0',['2_1_1','2_1_2','2_1_3']);
s1.add('0_1_1',['2_2_1','2_2_2','2_2_3']);
s1.add('0_1_2',['2_3_1','2_3_2','2_3_3']);
s1.add('0_2',['3_1','3_2','3_3']);
s1.add('0_2_0',['3_1_1','3_1_2','3_1_3']);
s1.add('0_2_1',['3_2_1','3_2_2','3_2_3']);
s1.add('0_2_2',['3_3_1','3_3_2','3_3_3']);
s1.init(3); // 几个下拉框
}
function Sel(id)
{
this.oParent=document.getElementById(id); //选择容器
this.data={}; // 存放数据
this.aSel=this.oParent.getElementsByTagName('select'); // 创建容器中的 select 下拉框
}
Sel.prototype=
{
init:function(num)
{
var This=this;
for(var i=1;i<=num;i++)
{
var oSel=document.createElement('select');
var opt=document.createElement('option');
opt.innerHTML='默认'; // 每个下拉框的初始值
oSel.appendChild(opt); // 每个下拉框的初始元素
oSel.index=i; //1,2,3
this.oParent.appendChild(oSel); // 添加初始元素
oSel.onchange=function() // 当下拉框改变的时候
{
This.change(this.index);
}
}
this.first();//创建第一个
},//初始化对象
add:function(key,val)
{
this.data[key]=val;
},//添加数据
first:function()
{
var arr=this.data['0'];
for(var i=0;i<arr.length;i++)
{
var opt=document.createElement('option');
opt.innerHTML=arr[i];
this.aSel[0].appendChild(opt);
}
},//创建第一个下拉菜单----元素添加数据
change:function(now)
{
var str='0';
for(i=0;i<now;i++) //now====0,1,2 如果now=0,循环时str=0_0
{
str+='_'+(this.aSel[i].selectedIndex-1);
//取得当前选中元素的下一级的数据
}
if(this.data[str]) //如果有数据
{
var arr=this.data[str];
this.aSel[now].options.length=1;
for(var i=0;i<arr.length;i++)
{
var opt=document.createElement('option');
opt.innerHTML=arr[i];
this.aSel[now].appendChild(opt);
} // -------------------------------添加数据
this.aSel[now].options[1].selected=true;
now++;
if(now<this.aSel.length)
{
this.change(now); // 更新下级
}
}
else
{
for(var i=now;i<this.aSel.length;i++)
{
this.aSel[i].options.length=1;
}// 返回默认值
}
}, // -------------------------change 结束
}
</script>
</head>
<body>
<div id="div1"></div>
</body>
</html>
js 联动下拉菜单的更多相关文章
- jQuery cxSelect 多级联动下拉菜单
随着电商热门,这种多层次的互动更充分地体现在下拉菜单,最明显的是多级联动地址下拉选择,因此,这里是一个简单的分享 jQuery cxSelect 多级联动下拉菜单 cxSelect 它是基于 jQue ...
- (实用篇)jQuery+PHP+MySQL实现二级联动下拉菜单
二级联动下拉菜单选择应用在在很多地方,比如说省市下拉联动,商品大小类下拉选择联动.本文将通过实例讲解使用jQuery+PHP+MySQL来实现大小分类二级下拉联动效果. 先看下效果 大类: 前端技术 ...
- 纯css和js版下拉菜单
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- js版本下拉菜单
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- JS实现下拉菜单的功能
<!DOCTYPE html> <html> <head> <meta charset = "utf8"> <title> ...
- php+ajax的三级联动下拉菜单
封装一个三级联动,就可以在任何页面进行引用了 先写个页面引用一下这个js <head> <meta http-equiv="Content-Type" conte ...
- ajax三级联动下拉菜单
ajax写三级联动,先写一个文件类吧,以后用的时候直接调用即可: 来找一张表: 实现: 中国地域的三级联动:省.市.区: 图: 说一下思路: (1)当用户选择省份的时候触发事件,把当前的省份的id通过 ...
- 2016/3/24 ①数据库与php连接 三种输出fetch_row()、fetch_all()、fetch_assoc() ②增删改时判断(布尔型) ③表与表之间的联动 ④下拉菜单 ⑤登陆 三个页面
①数据库与php连接 图表 header("content-type:text/html;charset=utf-8"); //第一种方式: //1,生成连接,连接到数据库上的 ...
- js模拟下拉菜单-键盘、鼠标(代码详解)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
随机推荐
- JavaSwing文件选择器 JFileChooser的使用
先看效果吧! 说明:选择文件或者文件夹.本例子就直接在控制台输出文件或者文件夹的路径.实际开发中,就可以将文件或文件夹的路径封装为File的实例来使用了. package test; import j ...
- Velocity加载模版文件
一.类路径 加载classpath目录下的vm文件,或者maven项目的resources路径下 Properties p = new Properties(); p.put("file.r ...
- 安装完Ubuntu 14.04后的几件事
周末折腾一下Ubuntu 14.04,稍作记录: 1. 切换源,我还是钟情163的(ps, 这里如果用的以前13.04时候163的源会有问题,记得配置最新的http://mirrors.163.com ...
- ie7下z-index失效问题解决方法
绝对定位元素的“有定位属性(relative或absolute)的父元素”在渲染层次时起到了主要作用,前面的被后面的覆盖了.解决办法就是给有定位属性的父元素设置z-index 解决办法: 父级元素加上 ...
- [转]MySQL5.6.22 安装
原文路径 http://jifeng3321.iteye.com/blog/2181517?utm_source=tuicool 由于一直做银行项目,所以一直在用oracle和db2,但最近自己想 ...
- jquery.pagination.js使用
直接上代码: <script type="text/javascript"> var pageIndex = 1; //页面索引初始值 var pageSize = 1 ...
- ES01 数据类型、正则表达式、身份证校验
1 基本数据类型 参见W3C的教程即可 2 正则表达式 参考博文:点击前往 3 身份证校验 参考博文:点击前往 <div class="panel panel-primary" ...
- iOS 本地加载js文件
#import "RootViewController.h" @interface RootViewController ()<UIWebViewDelegate> @ ...
- 机器人自主移动的秘密:SLAM与路径规划有什么关系?(三)
博客转载自:https://www.leiphone.com/news/201612/lvDXqY82OGNqEiyl.html 雷锋网(公众号:雷锋网)按:本文作者SLAMTEC(思岚科技公号sla ...
- iOS Simulator hang up ( Xcode4.6.3)
最近遇见个Xcode的bug,搞的十分郁闷. 具体现象是:程序前段时间都是好好的,可以运行,第二天开机,调试就无法进入模拟器.就连main()函数都进不了.模拟器完全挂起了.具体说来就是代码一句都没改 ...