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

作者:神秘网友 发布时间:2020-09-12 19:46:14

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

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

各个元素的点击事件其实是继承的父元素div的,可以使用开发者工具查看:
easyUI:使comboTree组合树根节点不可点击
大概思路:我猜想可能源码是根据元素类型再做具体的动作,我们尽量不去改源码,所以让我们要控制的子元素不继承父元素的事件。所以在加载成功后,通过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'}]}
			]
		);

easyUI:使comboTree组合树根节点不可点击相关教程

  1. 利用回溯算法解决组合求和问题及其优化
  2. 组合总和问题
  3. [LeetCode 组合总和Ⅲ No.216] 题解心得
  4. EBS INV:物料分类组合描述
  5. 【9月打卡~Leetcode每日一题】216. 组合总和 III(难度:中等)
  6. 题216. 组合总和 III
  7. 每日一题算法 : 2020年9月10日[组合总和 II] combinationSum2
  8. 《Leetcode of September 》回溯算法之:216. 组合总和 III