首页 > 其他分享 >243-layui 区域树xmSelect懒加载,且叶子节点有选择时,自动追溯父节点,并展开选中

243-layui 区域树xmSelect懒加载,且叶子节点有选择时,自动追溯父节点,并展开选中

时间:2023-12-22 12:31:43浏览次数:34  
标签:parent layui children id item 243 var true 节点

		var regionData = [];
		var url = ctx+'/base/region/queryByAll';
		var rtnRegion=admin.syncReq(url,{parentId:0});
		regionData = rtnRegion.data;
		active.renderRegionData(regionData,regionId);
		var regionSel = xmSelect.render({
			el: '#regionSel',
			autoRow: true,
			filterable: true,
			model: {
				label: {
					block: {
						//自定义渲染label, 默认渲染name, 回调参数(item, sels)
						template: function (item, sels) {
							var rtnLabel = '';
							var parent = item.parent;
							if(parent){
								if(parent.parent){
									rtnLabel=parent.parent.name+'/'
								}
								rtnLabel+=parent.name+'/';
							}
							rtnLabel+=item.name;
							return rtnLabel;
						},
					},
				},
				//展示类型, 下拉框形式: absolute, 直接显示模式: relative
				type: 'absolute',
			},
			tree: {
				//是否显示树状结构
				show: true,
				//是否展示三角图标
				showFolderIcon: true,
				//是否显示虚线
				showLine: false,
				//间距
				indent: 20,
				//默认展开节点的数组, 为 true 时, 展开所有节点
				expandedKeys: true,
				//是否严格遵守父子模式
				strict: false,
				lazy: true,
				load:function (item,cb) {
					if(item.type==3){
						cb([])
					}else{
						if(!item.children || item.children.length==0){
							var _rtn=admin.syncReq(url,{parentId:item.id});
							if(_rtn.data && _rtn.data.length>0){
								var children = _rtn.data;
								$.each(children,function (index,_item) {
									if(_item.type==3){
										_item.children = null;
									}
									var _parent = {name:item.name,id:item.id,type:item.type}
									if(item.parent){
										_parent = $.extend(_parent,{parent:item.parent});
									}
									_item = $.extend(_item,{ parent:_parent });
								})
								cb(children);
							}
						}else{
							cb([])
						}
					}

				}
			},
			height: '200px',
			// radio:true,
//            clickClose:true,
			toolbar: {
				show: true,
				list: [ 'CLEAR' ]
			},
			data(){
				return regionData;
			},
			on:function (data) {
				setTimeout(function (){
					var valueStr = regionSel.getValue("valueStr")
					var nameStr = regionSel.getValue("nameStr")
					$("[name=regionId]").val(valueStr);
					$("[name=regionName]").val(nameStr);
				},100)

			}
		});

		if(regionId){
			regionSel.setValue(regionId.split(","))
		}

递归查找父级节点 的实现:

var active = {
			//递归查找父级节点
			//取节点,得id、pid
			//比对顶级list,遍历,定义为n
			//若pid=n.id,则n.children=[{parentId:pid}],结束
			//若pid!=n.id,继续 goto X
			//X: 查父节点1,得id1、pid1
			//查父节点1.children=[{parentId:id1}]
			//比对顶级list,遍历,定义为n,
			//若pid1=n.id,则n.children=[{parentId:若pid1}],
			// 		同时遍历:n.children,定义为c,当c.id=查父节点1.id, 则c=查父节点1
			// 			结束
			//若pid1!=n.id,继续 goto X
			findParentNodesRecursion:function (treeData,pid){
				var rtn = admin.syncReq(url,{id:pid});
				var p1 = rtn.data[0];
				var id1 = p1.id;
				var pid1 = p1.parentId;
				rtn = admin.syncReq(url,{parentId:id1});
				p1.children = rtn.data;
				for(var i=0;i<treeData.length;i++){
					var n = treeData[i];
					if(pid1==n.id){
						rtn = admin.syncReq(url,{parentId:pid1});
						n.children = rtn.data;
						for(var j=0;j<n.children.length;j++){
							var c = n.children[j];
							if(c.id==p1.id){
								c = p1;
								n.children[j] = p1;
							}
						}
						return;
					}
				}
				active.findParentNodesRecursion(treeData,pid1)
			},
			findParentNodes:function (treeData,node){
				var id = node.id;
				var rtn = admin.syncReq(url,{id:id});
				node = rtn.data[0];
				var pid = node.parentId;
				for(var i=0;i<treeData.length;i++){
					var n = treeData[i];
					if(pid==n.id){
						rtn = admin.syncReq(url,{parentId:pid});
						n.children = rtn.data;
						return;
					}
				}
				active.findParentNodesRecursion(treeData,pid);
			},
			renderRegionData:function (treeData,selIds){
				if(!selIds){
					return;
				}
				var idArr = selIds.split(",");
				for(var i=0;i<idArr.length;i++){
					var rid = idArr[i];
					active.findParentNodes(treeData,{id:rid});
				}
			},
		}

标签:parent,layui,children,id,item,243,var,true,节点
From: https://blog.51cto.com/u_14816966/8934275

相关文章

  • 第四方支付系统(集成wxpay、alipay)_ LayUI基础
    23以蜡笔小新为开头写一篇藏头诗蜡月寒风正刺骨,笔耕不辍夜已深。小径穿行千百度,新春又至岁华新。暗恋一个人不敢表白怎么办暗恋一个人不敢表白是一个常见的问题,以下是一些建议来帮助你克服这种困境:了解自己:首先,你需要了解自己的情感和动机。思考一下你对这......
  • ClickHouse单节点安装配置
    1、从宿主机/opt目录下将clickhouse开头的相关文件复制到容器Master中的/opt/module/clickhouse路径中(若路径不存在,则需新建),将全部解压命令复制并粘贴至客户端桌面【Release\任务A提交结果.docx】中对应的任务序号下;#从宿主机复制文件到容器Masterdockercp/opt/clickhouse......
  • layui 时间控件 动态js渲染添加
    <tableclass="layui-table"id="myTable"><thead><tr><th>日期</th><th>操作</th></tr></thead><tbody><tr><td>......
  • SQLserver AlwaysOn 提交模式与节点的可用性
    接上文:https://www.cnblogs.com/wy123/p/17905118.html,关于AlwaysOn主副本与辅助副本之间提交模式与安全故障转移的话题参考AlwaysOn属性面板中的信息1,主节点异步提交模式:如果主要副本配置为“异步提交模式” ,则从节点不管是同步或者异步,主节点提交事务都无须等待从节点(永远......
  • 代码随想录算法训练营第四天|24.两两交换链表中的节点、19.删除链表的倒数第N个节点、
    LeetCode24.两两交换链表中的节点题目链接: 24.两两交换链表中的节点提示:链表问题,首先用虚拟头节点,让链表节点的处理具有一致性!!! LeetCode19.删除链表的倒数第N个节点题目链接:19.删除链表的倒数第N个节点注意点:快慢指针,链表删除元素得找到该元素的前一个元素!!! LeetCode......
  • 代码随想录算法训练营第四天| LeetCode24. 两两交换链表中的节点、19.删除链表的倒数
     LeetCode24.两两交换链表中的节点●今日学习的文章链接和视频链接代码随想录(programmercarl.com)题目链接24.两两交换链表中的节点-力扣(LeetCode)●自己看到题目的第一想法主要是把这个过程想清楚,链表交换的题目主要想明白要动几个指针,指针改变的顺序也要注意,如果......
  • k8s集群从一千节点增加到五千台节点遇到的瓶颈
    Kubernetes自从1.6起便号称可以承载5000个以上的节点,但是从数十到5000的路上,难免会遇到问题。在kubernetes5000之路上的经验,包括遇到的问题、尝试解决问题以及找到真正的问题。1、问题一:1~500个节点之后问题:kubectl有时会出现timeout(p.s.kubectl-v=6可以显示所......
  • 代码随想录算法训练营第四天 | 24. 两两交换链表中的节点,19.删除链表的倒数第N个节点,
    一、24.两两交换链表中的节点题目链接:LeetCode24.两两交换链表中的节点学习前:思路:未新增虚拟结点。节点数为0,1,2需要另外讨论。当节点数>=2时,返回的head值为第2个节点,需要3个指针first、second、prev,分别是第一个节点和第二个节点,以及第一个节点的前节点。while(first......
  • 19.删除链表的倒数第N个节点
    题目19.删除链表的倒数第N个节点要求给你一个链表,删除链表的倒数第n个结点,并且返回链表的头结点。答案先看看直接思路,首先遍历一遍,计算出元素的个数,之后计算出正向遍历要删除的元素,注意的是要创建一个虚拟节点,目的是可能删除头节点,如果删除头节点,没有虚拟节点,不易删除,当然......
  • 24. 两两交换链表中的节点
    题目24.两两交换链表中的节点要求给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。解答迭代的思路就是考虑清楚下一个节点是什么,举个实际的例子来解释代码,1→2→3→4→null,首先我先确定了最后......