jquery select选中表单特效三级联动
好久没发帖了,今天发一个jquery select的表单三级联动,希望能对有需要的朋友有点帮助。
js代码,当然还要加上jquery的包,应该都有的,这里就不发了。
<script type="text/javascript">
var threeSelectData={ "选择频道":{
val:"",
items:{
"二级子菜单":{
val:"",
items:{
"三级子菜单":""
}
}
}
}, "jquery特效":{
val:"jquery",
items:{
"jquery图片特效":{
val:"jqpic",
items:{
"jquery图片切换":"jqpic-01",
"jquery幻灯片":"jqpic-02",
"jquery图片滚动":"jqpic-03",
"jquery图片放大":"jqpic-04",
"jquery广告":"jqpic-05",
"jquery图片其它":"jqpic-06"
}
}, "jquery导航菜单":{
val:"jqnav",
items:{
"jquery动画菜单":"jqnav-01",
"jquery下拉菜单":"jqnav-02",
"jquery手风琴菜单":"jqnav-03",
"jquery导航其它":"jqnav-04"
}
}, "jquery选项卡特效":{
val:"jqtab",
items:{
"jquery选项卡切换":"jqtab-01",
"jquery滑动选项卡":"jqtab-02"
}
}, "jquery文字特效":{
val:"jqfont",
items:{
"jquery文字滚动":"jqfont-01",
"jquery文字切换":"jqfont-02",
"jquery文字其它":"jqfont-03"
}
}, "jquery表单特效":{
val:"jqform",
items:{
"jquery表单验证":"jqform-01",
"jquery表单美化":"jqform-02",
"jquery表单其它":"jqform-03"
}
}, "jquery滚动条美化":{
val:"jqscroll",
items:{}
}, "jquery评分,进度条,日期时间":{
val:"jqrate",
items:{}
}, "jquery提示框,弹出层,浮动层":{
val:"jqdiv",
items:{}
}, "jquery其它特效":{
val:"jqother",
items:{}
} }
}, "js特效":{
val:"js",
items:{ "js图片特效":{
val:"jspic",
items:{
"js图片切换":"jspic-01",
"js幻灯片":"jspic-02",
"js图片滚动":"jspic-03",
"js图片放大":"jspic-04",
"js广告":"jspic05",
"js图片其它":"jspic-06"
}
}, "js导航菜单":{
val:"jsnav",
items:{
"js动画菜单":"jsnav-01",
"js下拉菜单":"jsnav-02",
"js手风琴菜单":"jsnav-03",
"js导航其它":"jsnav-04"
}
}, "js选项卡特效":{
val:"jstab",
items:{
"js选项卡切换":"jstab-01",
"js滑动选项卡":"jstab-02"
}
}, "js文字特效":{
val:"jsfont",
items:{
"js文字滚动":"jsfont-01",
"js文字切换":"jsfont-02",
"js文字其它":"jsfont-03"
}
}, "js表单特效":{
val:"jsform",
items:{
"js表单验证":"jsform-01",
"js表单美化":"jsform-02",
"js表单其它":"jsform-03"
}
}, "js滚动条美化":{
val:"js-scroll",
items:{}
}, "js评分,进度条,日期时间":{
val:"js-rate",
items:{}
}, "js提示框,弹出层,浮动层":{
val:"js-div",
items:{}
}, "js其它特效":{
val:"js-other",
items:{}
} }
}, "flash特效":{
val:"flash",
items:{ "图片特效":{
val:"flash-pic",
items:{}
}, "导航菜单":{
val:"flash-nav",
items:{}
}, "文字特效":{
val:"flash-font",
items:{}
}, "其它":{
val:"flash-other",
items:{}
} }
}, "div+css教程":{
val:"divcss",
items:{ "div+css布局":{
val:"divcss-layout",
items:{}
}, "div+css菜单":{
val:"divcss-nav",
items:{}
}, "css3教程":{
val:"div-css3",
items:{}
}, "其它":{
val:"divcss-other",
items:{}
} }
}, "html5教程":{
val:"html5",
items:{ "html5特效":{
val:"html5-tx",
items:{}
}, "html5图表":{
val:"html5-map",
items:{}
}, "其它":{
val:"html5-other",
items:{}
} }
} }; var defaults = {
s1:'mainselect',
s2:'midselect',
s3:'backselect'
}; $(function(){
threeSelect(defaults);
}); function threeSelect(config){
var $s1=$("#"+config.s1);
var $s2=$("#"+config.s2);
var $s3=$("#"+config.s3);
var v1=config.v1?config.v1:null;
var v2=config.v2?config.v2:null;
var v3=config.v3?config.v3:null;
$.each(threeSelectData,function(k,v){
appendOptionTo($s1,k,v.val,v1);
}); $s1.change(function(){
$s2.html("");
$s3.html("");
if(this.selectedIndex==-1)
return; var s1_curr_val = this.options[this.selectedIndex].value; $.each(threeSelectData,function(k,v){
if(s1_curr_val==v.val){
if(v.items){
$.each(v.items,function(k,v){
appendOptionTo($s2,k,v.val,v2);
});
}
}
}); if($s2[0].options.length==0){
appendOptionTo($s2,"...","",v2);
} $s2.change(); }).change(); $s2.change(function(){
$s3.html("");
var s1_curr_val = $s1[0].options[$s1[0].selectedIndex].value;
if(this.selectedIndex==-1)
return; var s2_curr_val = this.options[this.selectedIndex].value; $.each(threeSelectData,function(k,v){
if(s1_curr_val==v.val){
if(v.items){
$.each(v.items,function(k,v){
if(s2_curr_val==v.val){
$.each(v.items,function(k,v){
appendOptionTo($s3.show(),k,v,v3);
});
}
}); if($s3[0].options.length==0){
appendOptionTo($s3.hide(),"...","",v3);
}
}
}
}); }).change(); function appendOptionTo($o,k,v,d){ var $opt=$("<option>").text(k).val(v); if(v==d){
$opt.attr("selected", "selected")
}
$opt.appendTo($o);
} }
</script>
html代码很简单:
<select id="mainselect" name="mainselect" style="width:120px;"></select>
<select id="midselect" name="midselect" style="width:220px;"></select>
<select id="backselect" name="backselect" style="width:160px;"></select>
jquery select选中表单特效三级联动的更多相关文章
- 基于jQuery+JSON的省市县 二级 三级 联动效果
省市区联动下拉效果在WEB中应用非常广泛,尤其在一些会员信息系统.电商网站最为常见.开发者一般使用Ajax实现无刷新下拉联动.本文将讲述,利用jQuery插件,通过读取JSON数据,实现无刷新动态下拉 ...
- 用jquery写的json省市县三级联动下拉
<form action="#" name="myform"> <label>省</label><select nam ...
- javaweb--json--ajax--mysql实现省市区三级联动(附三级联动数据库)
在web中,实现三级联动很常见,尤其是利用jquery+json.但是从根本上来说jquery并不是最能让人容易理解的,接下来从最基本的javascript开始,实现由javascript+json+ ...
- django项目中cxselect三级联动
下载cxselect插件放在static文件夹下 前端引入 <script src="/static/js/jQuery-1.8.2.min.js"></scri ...
- AngularJS系列:表单全解(表单验证,radio必选,三级联动,check绑定,form提交验证)
一.查看$scope -->寻找Form控制变量的位置 Form控制变量 格式:form的name属性.input的name属性.$... formName.inputField.$pristi ...
- jQuery实现select三级联动
参考:jQuery权威指南jQuery初步jQuery选择器jQuery操作domjQuery操作dom事件jQuery插件jQuery操作AjaxjQuery动画与特效jQuery实现导航栏jQue ...
- 简单jquery实现select三级联动
简单的jquery实现select三级联动 代码如下: <!DOCTYPE html> <html> <head> <meta charset="u ...
- Jquery select 三级联动 (需要JSON数据)
Scripts/Category.js //Jquery三级类别联动 $(function () { BindCategory(); }) function BindCategory() { var ...
- ajax验证表单元素规范正确与否 ajax展示加载数据库数据 ajax三级联动
一.ajax验证表单元素规范正确与否 以用ajax来验证用户名是否被占用为例 1创建表单元素<input type="text" id="t"> 2 ...
随机推荐
- 【UML】类图的几种关系总结
在UML类图中,常见的有以下几种关系:泛化(Generalization), 实现(Realization),关联(Association),聚合(Aggregation),组合(Compositi ...
- paip.提升性能----jvm参数调整.txt
paip.提升性能----jvm参数调整.txt 作者Attilax 艾龙, EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn.n ...
- atitit.web 推送实现方案集合(2)---百度云,jpush 极光推送 ,个推的选型比较.o99
atitit.web 推送实现方案集合(2)---百度云,jpush 极光推送 ,个推的选型比较.o99 1.1. 云推送有推送次数或频率的限制吗? 1 1.2. 推送的消息长度 1 1.3. 离线消 ...
- paip.取当天记录的方法sql跟hql hibernate
paip.取当天记录的方法sql跟hql hibernate #------两个方法...函数法和日期计算法.. 函数法: DATEDIFF(d,createTime,GETDATE())=0 / ...
- 共享jQuery/Eclipse/SVN/PS/DW/的API文档
1:jQuery的API和jquery.js和jquery.min.js 链接:http://pan.baidu.com/s/1gf7GD83 密码:tbt1 2:虚拟机软件和frdora和ubunt ...
- Exception in thread "main" java.lang.UnsupportedClassVersionError: org/apache/ma ven/cli/Maven/java与javac版本不一致问题
编译的时候 中出现如下异常: Exception in thread "main" Java.lang.UnsupportedClassVersionError: org/apac ...
- android: 服务的生命周期
9.4 服务的生命周期 之前章节我们学习过了活动以及碎片的生命周期.类似地,服务也有自己的生命周期, 前面我们使用到的 onCreate().onStartCommand().onBind()和 ...
- nginx的反向代理和负载均衡的区别
反向代理,是把一些静态资源存储在服务器上,当用户有请求的时候,就直接返回反向代理服务器上的资源给用户,而如果反向代理服务器上没有的资源,就转发给后面的负载均衡服务器,负载均衡服务器再将请求分发给后端的 ...
- SqlServer2008R2用Windows身份登录18456错误解决
// 重装系统后发现SqlServer2008R2使用Windows身份验证不能进行连接,如下图: 以前经常会碰到SqlServer 身份验证连接失败,Windows身份验证的连接失败还是第一次,试了 ...
- 用SDWebImage渐变加载图片
用SDWebImage渐变加载图片 使用 使用请详细查看源码,只需要给定一个图片地址以及一个placeHolder图片(非必须)即可. 效果 源码 https://github.com/YouXian ...