文档章节

多级下拉框

skq
 skq
发布于 2015/09/23 17:52
字数 261
阅读 312
收藏 8
(function($){
	$.fn.AjaxSelect = function(options) {
		var s = { url : "" // ajax查询的网址
		, change : function(obj) {} // 改变选项的回调,参数为当前的jq对象
		, val : "id"
		, text : "title",
		data : '',
		};
		// var s = $.extend(defaultVal, options);
		var s = typeof (options) == "string" ? $.extend(s, { url : options }) : $.extend(s, options);
		var nthis = $(this);
		nthis.each(function() {
			var $this = $(this);
			var addChange = function(jqObj) {
				jqObj.change(function() {
					var selects = $this.find("select");
					var sthis = $(this);
					
					selects.eq(selects.index(this)).nextAll().remove();
					var sval = sthis.val();
					if (sval == '')
						return;
					// 读数据
					$.getJSON(s.url + sval, function(data) {
						if (data[0]) {
							// 对0号对象进行复制形式
							var tpl = selects.eq(0).clone();
							tpl.removeAttr('id').children().slice(1).remove();
							tpl.attr('id', selects.eq(0).attr('id')+'_'+(selects.length+1));
							$.each(data, function(i, item) {
								tpl.append('<option value="' + item[s.val] + '">' + item[s.text] + '</option>');
							});
							$this.append(tpl);
							addChange(tpl);
						}
						s.change(sthis);
					});
				});
			}
			addChange($this.find("select"));
		});
	}
})(jQuery);

调用方法如下:

// AjaxSelect by: qqq
	$(".ajax-select").each(function(i, e){
		var $this = $(e);
		var url = $this.attr('url');
		var data = $this.attr('data');
		var arr  = data.split(',');
		$this.AjaxSelect({url: url, text: 'name', val: 'id', data: data, change: function(obj){
			var ind = obj.index();
			if( obj.val() == arr[ind] ){
				obj.next().val( arr[ind+1] ).change();
			}
		} });
		$this.find("select").eq(0).val(arr[0]).change();
	});


HTML

<dd class="ajax-select" url="index.php?pid=" data="1,2,3">
    <select id="aaa" name="aaa">
        <option value="">请选择</option>
        <option value="1">111</option>
    </select>
</dd>


© 著作权归作者所有

skq

skq

粉丝 10
博文 76
码字总数 13135
作品 0
武汉
私信 提问
asp.net控件 --NetWebControl

包含asp.net分页控件、下拉多级联动控件、弹出选择框控件、多级显示控件以及实体的自动添加修改控件。多数控件正在完善中。。。 测试项目在ControlTest目录下

曹志强
2014/05/16
1K
0
JQuery Ajax实现Select多级关联动态绑定数据

关于JQuery选择插件的使用在这里有些心得和大家分享一下,希望能帮到大家。 jQuery选择插件分为基本版和美化版,重点说下美化版,如下图所示: 相比最原始的版本,美化后的选择插件可以说是很...

海岸线的曙光
2018/10/25
99
0
Javascript工具包

是一个免费的开放的Javascript工具包,里面有很多常用的JS工具。不依赖任何Javascript包。 核心组件: 个性化下拉列表 个性化下拉列表 置顶置底 弹出窗口 表格排序 JS文字热点链接提示 自定义...

匿名
2013/01/06
6.5K
14
input搜索下拉提示框,支持拼音检索、过滤、级联、自定义数据源的ajax异步下拉展示

为解决大数据量下拉字典效率及操作问题,整理出通用的数据字典模块,所有字典数据可在数据库维护,在大数据量时采用分页下拉的展示方式,同时支持拼音简拼搜索,代码项、代码值搜索等,支持无...

神话无名
2018/06/07
716
1
Eova 1.5 稳定版,Java Web 快速开发平台

Eova不做最屌,只做经济适用,使用众所周知的技术和概念玩出不一样的精彩! 码海无边 回头是岸! 从1.0到1.5,Eova实现了从无到有的过程,感谢大家一路支持和陪伴! V1.5代号为稳定版,至此E...

Jieven
2016/01/20
11.8K
53

没有更多内容

加载失败,请刷新页面

加载更多

Activity启动模式二

上篇文章Activity启动模式一主要介绍了Activity的四种启动模式,这些启动模式都是在AndroidManifest中进行配置的。除此之外,Android系统还通过Intent类提供了一些标志位,同样可以指定Activ...

ltlovezh
25分钟前
4
0
三原色还原

1、Color Filter Array — CFA 随着数码相机、手机的普及,CCD/CMOS 图像传感器近年来得到广泛的关注和应用。 图像传感器一般都采用一定的模式来采集图像数据,常用的有 BGR 模式和 CFA 模式...

天王盖地虎626
36分钟前
3
0
kubernetes pod exec接口调用

正文 一般生产环境上由于网络安全策略,大多数端口是不能为集群外部访问的。多个集群之间一般都是通过k8s的ApiServer组件提供的接口通信,如https://192.168.1.101:6443。所以在做云平台时,...

码农实战
今天
8
0
3_数组

3_数组

行者终成事
今天
8
0
经典系统设计面试题解析:如何设计TinyURL(二)

原文链接:https://www.educative.io/courses/grokking-the-system-design-interview/m2ygV4E81AR 编者注:本文以一道经典的系统设计面试题:《如何设计TinyURL》的参考答案和解析为例,帮助...

APEMESH
今天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部