1.如何让用户只能点击页子节点

var setting = {
callback: {
beforeClick: zTreeBeforeClick
}
};
function zTreeBeforeClick(treeId, treeNode, clickFlag) {
return !treeNode.isParent;//当是父节点 返回false 不让选取
};

2.用户在点击之前只能点击三项

    function zTreeBeforClick(treeId,treeNode,clickFlag){
if(treeNode.checked)return true;//如果是点击取消就不执行下面
var zTree=$.fn.zTree.getZTreeObj(treeId);
var nodes=zTree.getCheckedNodes(true);
var num=0;
for(var i=0;i<nodes.length;i++){
if(!nodes[i].isParent)num++;
}
if(num>2){
alert("选择超出");
return false;
}
}

3.页面记载的时候默认选择第一个子项的最后一个子节点,并且点击

单选:

    var el=zTreeObj.getNodes()[0];
while(el.isParent){
el=el.children[0];
}
zTreeObj.selectNode(el);
setting.callback.onClick(null, zTreeObj.setting.treeId, el);//设置第一个节点被点击

多选

    var el=zTreeObj.getNodes()[0];
while(el.isParent){
zTreeObj.expandNode(el,true,false,false);//展开当前节点
el=el.children[0];
}
zTreeObj.checkNode(el);

4.将勾选的节点,组成字符串,用“\”隔开,最后一个不需要;

  思路:不同于往常的写法点

    1.用数组的reduce方法代替了for循环

    2.原本是在字符串的最后部分加上“\”变成了在字符串前面添加“\”(除去第一个)

    var nodes=treeObj.getCheckedNodes(true);
data.groupTreeCode=nodes.reduce(function(o,v,i){
if(!!o){o+"\\"}
o+=v.original_id;
return o;
})

5.只获取选中的叶子节点的id,用“;”隔开

    var nodes=treeObj.getCheckedNodes(true);
data.groupTreeCode=nodes.reduce(function(o,v,i){
if(!v.isParent){
if(o==undefined){
o="";
}
if(!!o){o+=";"}
o+=v.id;
}
return o;
})

7.ztree不能跨级勾选(两个父节点)

思路:

  在勾选之前的事件里,

  获取之前勾选的节点最前一级的id,

  再得到本次点击节点的最上一级的id,用while循环得到

  两者进行对比,不一样就return false

代码:

    function zTreebeforeCheck(treeId, treeNode){
var treeObj=$.fn.zTree.getZTreeObj(treeId);
var selnode=treeObj.getCheckedNodes();
var lastCheckPid="";//上一次选中的父id
var thisCheckPid=""//本次选中的父id
if(selnode.length>0){
lastCheckPid=selnode[0].id;
}else{
return true//如果之前一个都没有勾选
}
var el=treeNode;
while(!!el.getParentNode()){//如果有父级找父级的id
el=el.getParentNode();
}
thisCheckPid=el.id;
if(thisCheckPid===lastCheckPid){
return true
}else{
//window.wxc.xcConfirm("不能跨节点勾选,请重新选择!", window.wxc.xcConfirm.typeEnum.warning);
window.wxc.xcConfirm("不能跨节点勾选,请重新选择!", window.wxc.xcConfirm.typeEnum.error);
return false
}
}

为了更好的用户体验,可以在else中将页面中所有的节点取消勾选,然后return true 这样一来就可以实现跨级勾选就去掉原来的勾选

        thisCheckPid=el.id;
if(thisCheckPid===lastCheckPid){
return true
}else{
//window.wxc.xcConfirm("不能跨节点勾选,请重新选择!", window.wxc.xcConfirm.typeEnum.error);
//return false
//清除掉页面选中的节点
treeObj.checkAllNodes(false);
return true
}

ztree框架使用问题汇总的更多相关文章

  1. J2EE进阶(十)SSH框架整合常见问题汇总(一)

    SSH框架整合常见问题汇总(一) 前言 以下所列问题具有针对性,但是遇到同类型问题时均可按照此思路进行解决. HTTP Status 404 - No result defined for actio ...

  2. Java工程师三大框架面试题汇总

    1. Hibernate3 提供了属性的延迟加载功能? 当Hibernate在查询数据的时候,数据并没有存在与内存中,当程序真正对数据的操作时,对象才存在与内存中,就实现了延迟加载,他节省了服务器的内 ...

  3. Linux界面自动化测试框架不完全汇总

    首先可参考wiki此文,非常详尽:https://en.wikipedia.org/wiki/List_of_GUI_testing_tools 以下是我调研并实验过的(实验环境ubuntu 16.0 ...

  4. J2EE进阶(十二)SSH框架整合常见问题汇总(三)

    在挂失用户时,发现userid值为空,但是在前台输入处理账号22时,通过后台输出可以看出,后台根据前端输入在数据库中查询到结果对象并输出该对象的userid,而且Guashi对象也获取到了其值. 解决 ...

  5. vue前端框架面试问题汇总

    1.active-class是哪个组件的属性?嵌套路由怎么定义?答:vue-router模块的router-link组件. 2.怎么定义vue-router的动态路由?怎么获取传过来的动态参数? 答: ...

  6. CodeIgniter框架——知识要点汇总

    NO1.学习要点: 一.CodeIgniter 框架的简介 二.CodeIgniter 框架的安装 三.CodeIgniter 框架的目录结构分析 四.CodeIgniter 框架是如何工作的? 五. ...

  7. ASP.NET Core框架揭秘[博文汇总-持续更新]

    第1部分 跨平台开发体验 1 跨平台开发体验 001 跨平台开发体验: Windows [上篇]         002 跨平台开发体验: Windows [中篇]        003 跨平台开发体 ...

  8. 全新升级的AOP框架Dora.Interception[汇总,共6篇]

    多年之前利用IL Emit写了一个名为Dora.Interception(github地址,觉得不错不妨给一颗星)的AOP框架.前几天利用Roslyn的Source Generator对自己为公司写的 ...

  9. ue4框架C++语法汇总文章

    1.Run external .exe file TCHAR* url = TEXT("C:\\windows\\system32\\calc.exe"); FPlatformPr ...

随机推荐

  1. [转]windows7远程桌面连接失败:发生身份验证错误。要求的函数不受支持

    转至:https://jingyan.baidu.com/article/d169e18604ca86436611d821.html 系统升级后出现远程连接报错,“发生身份验证错误.要求的函数不受支持 ...

  2. 关于 href="\\#" 和 return false

    href="\\#"  跳转到本页 return false 相当于不刷新 href="javascript:void(0)"   或者 href=" ...

  3. 关于nosql的讲解

    Data Base  关于nosql的讲解 nosql非关系型数据库. 优点: 1.可扩展 2.大数据量,高性能 3.灵活的数据模型 4.高可用 缺点: 1.不正式 2.不标准 非关系型数据库有哪些: ...

  4. 201621123012 《Java程序设计》第1周学习总结

    1. 本章学习总结 学习了java的理论知识和它与C语言的差别,什么是JVM,区分JRE与JDK并学习JAVA环境的安装.熟悉控制台下的常用命令,java函数的编写.熟练使用编写JAVA所需要的工具( ...

  5. Delphi XE8中开发DataSnap程序常见问题和解决方法 (-)启动创建好的DBExpress工程时候报错了!

    当我们成功创建了使用DBExpress的DataSnap的服务器和客户端程序后,我们关闭了当前工程,当我们再次打开时候,有可能会出现这样的问题: 问题原因:这个问题是因为当前工程组默认启动的是客户端工 ...

  6. luoguP4735 最大异或和

    https://www.luogu.org/problemnew/show/P4735 令 s 数组为 a 数组的异或前缀,则题目要求的式子可变为 s[p - 1] ^ s[n] ^ x,s[n] ^ ...

  7. loj#6437. 「PKUSC2018」PKUSC(计算几何)

    题面 传送门 题解 计算几何的东西我好像都已经忘光了-- 首先我们可以把原问题转化为另一个等价的问题:对于每一个敌人,我们以原点为圆心,画一个经过该点的圆,把这个圆在多边形内部的圆弧的度数加入答案.求 ...

  8. 八大排序算法的python实现(一)直接插入排序

    刚参考网上的以及书上的资料把这八大算法又复习了一遍,感悟就是:有些算法原理真的很简单,一看就懂,但实现起来总是有这样那样的问题. 闲言少叙,先贴代码,之后再以自己的理解,以及自己在理解与实现的过程中遇 ...

  9. Python如何在子类里扩展父类的property?

    <python cookbook>8.8节讨论子类扩展property时,一开始都晕了,思考了半天才勉强弄懂一点,赶快记下来.废话不多说,先上代码: class Person: def _ ...

  10. Linux 使用echo向文件末尾追加命令

    //echo后边用单引号包围要添加的内容 echo 'add content'>>/home/data/test.sh 注意>>表示在原来的文件末尾上进行追加,如果使用的是&g ...