easyUI:使comboTree组合树根节点不可点击

1 篇文章 0 订阅
1 篇文章 0 订阅

各个元素的点击事件其实是继承的父元素div的,可以使用开发者工具查看:

大概思路:我猜想可能源码是根据元素类型再做具体的动作,我们尽量不去改源码,所以让我们要控制的子元素不继承父元素的事件。所以在加载成功后,通过onLoadSuccess方法,取到各个元素,取消他事件的冒泡迭代。

疑问:为毛onLoadSuccess:function(node,data)的node获取到是空的,为什么,为什么?如果有大神知道还望不吝赐教!

代码:

// 加载分类数据
		$("#1").combotree({
			lines:true,// 显示树线条
			onBeforeSelect:function(node){ // 	节点被选中前触发,返回 false 则取消选择动作(但是返回false,下拉选项依旧会关闭)
				if(node.attributes=="root"){
					return false;
				}else{
					return true;
				}
				// 加载存货编码列表
			},
			onLoadSuccess:function(node,data){// 数据加载成功后
				$(".tree-title").each(function(){
					var b = $(this).prev().hasClass("tree-folder");// 判断元素是否为根节点或子节点(通过文件图标判断)
					if(b){
						$(this).attr("style","display:inline-block;width:100%;");// 防止点击到后面的空白区域,让span把区域填满
						$(this).prev().click(function(e){
							e.stopPropagation();// 取消事件的冒泡迭代
						});
						$(this).click(function(e){
							e.stopPropagation();// 取消事件的冒泡迭代
						});
					}
				});
			}
		});
		
		// 加载数据
		$("#1").combotree('loadData', 
			[{"id":1,"text":"1234",attributes:"root","children":[{attributes:"children","id":3,"text": 'node241'},{attributes:"children","id":4,"text": 'node242'}]},
			 {"id":2,"text":"1235",attributes:"root","children":[{attributes:"children","id":3,"text": 'node241'},{attributes:"children","id":4,"text": 'node242'}]}
			]
		);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值