国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

jquery zTree異步加載、模糊搜索簡(jiǎn)單實(shí)例分享

2019-11-20 10:21:01
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文實(shí)例為大家講解了jquery zTree樹(shù)插件的基本使用方法,具體內(nèi)容如下

一、節(jié)點(diǎn)模糊搜索功能:搜索成功后,自動(dòng)高亮顯示并定位、展開(kāi)搜索到的節(jié)點(diǎn)。

二、節(jié)點(diǎn)異步加載:1、點(diǎn)擊展開(kāi)時(shí)加載數(shù)據(jù);2、選中節(jié)點(diǎn)時(shí)加載數(shù)據(jù)。
前臺(tái)代碼如下:

<script type="text/javascript"> //ztree設(shè)置 var setting = { view: { fontCss: getFontCss }, check: { enable: true }, data: { simpleData: { enable: true, idKey: "id", pIdKey: "pId", rootPId: 0 } }, async: { enable: true, url: "#{getStudentsJsonUrl}", autoParam: ["id", "level"] }, callback: { beforeCheck: zTreeBeforeCheck, onNodeCreated: zTreeOnNodeCreated, beforeExpand: zTreeBeforeExpand } }; var reloadFlag = false; //是否重新異步請(qǐng)求 var checkFlag = true; //是否選中 //節(jié)點(diǎn)展開(kāi)前 function zTreeBeforeExpand(treeId, treeNode) { reloadFlag = false; return true; }; //節(jié)點(diǎn)創(chuàng)建后 function zTreeOnNodeCreated(event, treeId, treeNode) { var zTree = $.fn.zTree.getZTreeObj(treeId); if (reloadFlag) { if (checkFlag) { zTree.checkNode(treeNode, true, true); } if (!treeNode.children) { zTree.reAsyncChildNodes(treeNode, "refresh"); } } }; //選中節(jié)點(diǎn)前 function zTreeBeforeCheck(treeId, treeNode) { var zTree = $.fn.zTree.getZTreeObj(treeId); if (!treeNode.children) { reloadFlag = true; checkFlag = true; zTree.reAsyncChildNodes(treeNode, "refresh"); } return true; } //頁(yè)面加載完成 _run(function () { require(['zTree/js/jquery.ztree.all-3.5'], function () { $.ajax({ type: "POST", url: "#{getStudentsJsonUrl}", success: function (data) { if (data && data.length != 0) { //如果結(jié)果不為空 $.fn.zTree.init($("#tree"), setting, data); } else { //搜索不到結(jié)果 } } }); }); //提交 $("#inputSubmit").click(function () { var zTree = $.fn.zTree.getZTreeObj("tree"); var nodes = zTree.getCheckedNodes(true); var ids = ""; var names = ""; for (var i = 0; i < nodes.length; i++) { //遍歷選擇的節(jié)點(diǎn)集合 if (!nodes[i].isParent) { ids += nodes[i].id.replace("level" + nodes[i].level, "") + ","; names += nodes[i].name + ","; } } Simpo.ui.box.hideBox(); parent.$(".boxFrm").contents().find("#inputRange").val(names.substr(0, names.length - 1)); parent.$(".boxFrm").contents().find("#hidRange").val(ids.substr(0, ids.length - 1)); }) }); //查找節(jié)點(diǎn) var lastNodeList = []; var lastKey; function searchNode() { var zTree = $.fn.zTree.getZTreeObj("tree"); var key = $.trim($("#inputSearchNode").val()); if (key != "" && key != lastKey) { nodeList = zTree.getNodesByParamFuzzy("name", key); for (var i = 0, l = lastNodeList.length; i < l; i++) { //上次查詢的節(jié)點(diǎn)集合取消高亮 lastNodeList[i].highlight = false; zTree.updateNode(lastNodeList[i]); } zTree.expandAll(false); //全部收縮 if (nodeList.length > 0) { for (var i = 0, l = nodeList.length; i < l; i++) { //遍歷找到的節(jié)點(diǎn)集合 if (nodeList[i].getParentNode()) { zTree.expandNode(nodeList[i].getParentNode(), true, false, false); //展開(kāi)其父節(jié)點(diǎn) } nodeList[i].highlight = true; zTree.updateNode(nodeList[i]); } } zTree.refresh(); // 很重要,否則節(jié)點(diǎn)狀態(tài)更新混亂。 lastNodeList = nodeList; lastKey = key; } } //加載數(shù)據(jù) function loadData() { var zTree = $.fn.zTree.getZTreeObj("tree"); var rootNodes = zTree.getNodes(); reloadFlag = true; checkFlag = false; for (var i = 0; i < rootNodes.length; i++) { if (!rootNodes[i].children) { zTree.reAsyncChildNodes(rootNodes[i], "refresh"); //異步加載 } } } //全部收縮 function closeAll() { var zTree = $.fn.zTree.getZTreeObj("tree"); if ($("#inputCloseAll").val() == "全部收縮") { zTree.expandAll(false); $("#inputCloseAll").val("全部展開(kāi)") } else { zTree.expandAll(true); $("#inputCloseAll").val("全部收縮") } } //高亮樣式 function getFontCss(treeId, treeNode) { return (treeNode.highlight) ? { color: "#A60000", "font-weight": "bold"} : { color: "#333", "font-weight": "normal" }; }</script>
<div style="width: 200px; height: 260px; overflow: auto; border: solid 1px #666;"> <ul id="tree" class="ztree"> </ul> </div>

后臺(tái)代碼(后臺(tái)返回Json數(shù)據(jù)):

 public void SelStudent() { set("getStudentsJsonUrl", to(GetStudentsJson)); } public void GetStudentsJson() { List<Dictionary<string, string>> dicList = new List<Dictionary<string, string>>(); string level = ctx.Post("level"); string id = ctx.Post("id"); if (strUtil.IsNullOrEmpty(id)) { #region 加載班級(jí) //獲取當(dāng)前登錄用戶 Sys_User user = AdminSecurityUtils.GetLoginUser(ctx); //獲取當(dāng)前用戶關(guān)聯(lián)的老師 Edu_Teacher teacher = edu_TeacService.FindByUserId(user.Id); //獲取班級(jí)集合 List<Edu_ClaNameFlow> list = edu_ClaNameFlowService.GetListByTeacherId(teacher.Id); foreach (Edu_ClaNameFlow item in list) { Dictionary<string, string> dic = new Dictionary<string, string>(); dic.Add("id", "level0" + item.Calss.Id.ToString()); dic.Add("pId", "0"); dic.Add("name", item.Gra.Name + item.Calss.Name); dic.Add("isParent", "true"); dicList.Add(dic); } #endregion } else { if (level == "0") { //加載學(xué)生 List<Edu_Student> list = edu_StudService.GetListByClassId(id.Replace("level0", "")); foreach (Edu_Student item in list) { Dictionary<string, string> dic = new Dictionary<string, string>(); dic.Add("id", "level1" + item.Id.ToString()); dic.Add("pId", id); dic.Add("name", item.Name); dic.Add("isParent", "false"); dicList.Add(dic); } } } echoJson(dicList); }

三、基于cookie實(shí)現(xiàn)zTree樹(shù)刷新后,展開(kāi)狀態(tài)不變

1、除了引用jQuery和zTree的JS外,引用cookie的JS:

復(fù)制代碼 代碼如下:
<script type="text/javascript" src="~/Scripts/jquery-treeview/lib/jquery.cookie.js"></script>

2、JS代碼:

$(function () { //ztree設(shè)置 var setting = { data: {  simpleData: {  enable: true,  idKey: "id",  pIdKey: "pId",  rootPId: null  } }, callback: {  onExpand: onExpand,  onCollapse: onCollapse } }; $.ajax({ type: "POST", url: "/Tech/TemplateTypeManage/GetData", success: function (data) {  if (data && data.length != 0) {  $.fn.zTree.init($("#tree"), setting, data);  var treeObj = $.fn.zTree.getZTreeObj("tree");  var cookie = $.cookie("z_tree" + window.location);  if (cookie) {   z_tree = JSON2.parse(cookie);   for (var i = 0; i < z_tree.length; i++) {   var node = treeObj.getNodeByParam('id', z_tree[i])   treeObj.expandNode(node, true, false)   }  }  } } });});//end $function onExpand(event, treeId, treeNode) { var cookie = $.cookie("z_tree" + window.location); var z_tree = new Array(); if (cookie) { z_tree = JSON2.parse(cookie); } if ($.inArray(treeNode.id, z_tree) < 0) { z_tree.push(treeNode.id); } $.cookie("z_tree" + window.location, JSON2.stringify(z_tree))}function onCollapse(event, treeId, treeNode) { var cookie = $.cookie("z_tree" + window.location); var z_tree = new Array(); if (cookie) { z_tree = JSON2.parse(cookie); } var index = $.inArray(treeNode.id, z_tree); z_tree.splice(index, 1); for (var i = 0; i < treeNode.children.length; i++) { index = $.inArray(treeNode.children[i].id, z_tree); if (index > -1) z_tree.splice(index, 1); } $.cookie("z_tree" + window.location, JSON2.stringify(z_tree))}

更多關(guān)于ztree控件的內(nèi)容,請(qǐng)參考專題《jQuery插件ztree使用匯總》

以上就是關(guān)于樹(shù)插件zTree異步加載、模糊搜索簡(jiǎn)單實(shí)例講解,希望對(duì)大家的學(xué)習(xí)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 贵港市| 武川县| 拜泉县| 唐河县| 娱乐| 阜南县| 桐柏县| 竹山县| 怀宁县| 南郑县| 丰台区| 武山县| 和龙市| 阳新县| 元阳县| 九寨沟县| 临海市| 金华市| 宜兴市| 清河县| 特克斯县| 迭部县| 禹州市| 察哈| 中牟县| 云龙县| 长泰县| 托克逊县| 齐河县| 松滋市| 漳浦县| 丰原市| 锡林浩特市| 新疆| 丰镇市| 康平县| 甘泉县| 宜兰县| 阜宁县| 峡江县| 如皋市|