全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

jQuery树控件zTree使用方法详解(一)

一、节点模糊搜索功能:搜索成功后,自动高亮显示并定位、展开搜索到的节点。

二、节点异步加载:1、点击展开时加载数据;2、选中节点时加载数据。

前台代码如下:

js:

<script type="text/javascript">
//ztree设置
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; //是否重新异步请求
var checkFlag = true; //是否选中

//节点展开前
function zTreeBeforeExpand(treeId, treeNode) {
reloadFlag = false;
return true;
};

//节点创建后
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");
}
}
};

//选中节点前
function zTreeBeforeCheck(treeId, treeNode) {
var zTree = $.fn.zTree.getZTreeObj(treeId);
if (!treeNode.children) {
reloadFlag = true;
checkFlag = true;
zTree.reAsyncChildNodes(treeNode, "refresh");
}
return true;
}

//页面加载完成
_run(function () {
require(['zTree/js/jquery.ztree.all-3.5'], function () {
$.ajax({
type: "POST",
url: "#{getStudentsJsonUrl}",
success: function (data) {
if (data && data.length != 0) { //如果结果不为空
$.fn.zTree.init($("#tree"), setting, data);
}
else { //搜索不到结果

}
}
});
});

//提交
$("#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++) { //遍历选择的节点集合
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));
})
});

//查找节点
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++) { //上次查询的节点集合取消高亮
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++) { //遍历找到的节点集合
if (nodeList[i].getParentNode()) {
zTree.expandNode(nodeList[i].getParentNode(), true, false, false); //展开其父节点
}
nodeList[i].highlight = true;
zTree.updateNode(nodeList[i]);
}
}
zTree.refresh(); // 很重要,否则节点状态更新混乱。
lastNodeList = nodeList;
lastKey = key;
}
}

//加载数据
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("全部展开")
}
else {
zTree.expandAll(true);
$("#inputCloseAll").val("全部收缩")
}
}

//高亮样式
function getFontCss(treeId, treeNode) {
return (treeNode.highlight) ? { color: "#A60000", "font-weight": "bold"} : { color: "#333", "font-weight": "normal" };
}
</script>

html:

 <div style="width: 200px; height: 260px; overflow: auto; border: solid 1px #666;">
 <ul id="tree" class="ztree">
 </ul>
 </div>

后台代码(后台返回Json数据):

 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 加载班级
 //获取当前登录用户
 Sys_User user = AdminSecurityUtils.GetLoginUser(ctx);
 //获取当前用户关联的老师
 Edu_Teacher teacher = edu_TeacService.FindByUserId(user.Id);
 //获取班级集合
 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")
 {
  //加载学生
  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);
 }

更多关于ztree控件的内容,请参考专题《jQuery插件ztree使用汇总》 。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# jQuery  # 树控件  # zTree  # jquery zTree异步加载、模糊搜索简单实例分享  # jQuery使用zTree插件实现树形菜单和异步加载  # jQuery zTree加载树形菜单功能  # Jquery zTree 树控件异步加载操作  # jquery zTree异步加载简单实例讲解  # JQuery ztree带筛选、异步加载实例讲解  # jquery ztree实现模糊搜索功能  # jquery zTree异步加载简单实例分享  # Jquery树插件zTree用法入门教程  # 基于cookie实现zTree树刷新后展开状态不变  # 加载  # 遍历  # 很重要  # 更多关于  # 请参考  # 大家多多  # 为空  # 其父  # 搜索功能  # _run  # require  # refresh  # children  # reAsyncChildNodes  # POST  # success  # ajax 


相关文章: 网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?  网站制作网站,深圳做网站哪家比较好?  建站OpenVZ教程与优化策略:配置指南与性能提升  建站与域名管理如何高效结合?  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析  建站之星后台搭建步骤解析:模板选择与产品管理实操指南  如何用美橙互联一键搭建多站合一网站?  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  建站主机是什么?如何选择适合的建站主机?  如何快速搭建FTP站点实现文件共享?  哈尔滨网站建设策划,哈尔滨电工证查询网站?  图册素材网站设计制作软件,图册的导出方式有几种?  如何使用Golang安装API文档生成工具_快速生成接口文档  ,在苏州找工作,上哪个网站比较好?  在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?  三星网站视频制作教程下载,三星w23网页如何全屏?  建站VPS能否同时实现高效与安全翻墙?  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  建站之星图片链接生成指南:自助建站与智能设计教程  深圳企业网站制作设计,在深圳如何网上全流程注册公司?  如何通过FTP空间快速搭建安全高效网站?  如何撰写建站申请书?关键要点有哪些?  网站制作报价单模板图片,小松挖机官方网站报价?  建站org新手必看:2024最新搭建流程与模板选择技巧  如何在云服务器上快速搭建个人网站?  Swift中swift中的switch 语句  如何选择服务器才能高效搭建专属网站?  如何快速搭建响应式可视化网站?  如何在Windows 2008云服务器安全搭建网站?  湖北网站制作公司有哪些,湖北清能集团官网?  建站之星如何修改网站生成路径?  c# 在高并发下使用反射发射(Reflection.Emit)的性能  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?  太原网站制作公司有哪些,网约车营运证查询官网?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  css网站制作参考文献有哪些,易聊怎么注册?  如何用搬瓦工VPS快速搭建个人网站?  网站制作服务平台,有什么网站可以发布本地服务信息?  Bpmn 2.0的XML文件怎么画流程图  如何在阿里云部署织梦网站?  如何自定义建站之星网站的导航菜单样式?  Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  在线制作视频网站免费,都有哪些好的动漫网站?  如何挑选高效建站主机与优质域名?  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  再谈Python中的字符串与字符编码(推荐) 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。