记得之前有项目做过,但是不记得当时怎么处理的了,后来想了想整体思路是:
判断是不是父节点,如果是,再判断是不是半选状态,是半选不存储;如果不是父节点,判断父节点是不是半选状态,如果是则存储,如果不是则不存储。
function zTreeOnCheck(event, treeId, treeNode) {
var treeObj = $.fn.zTree.getZTreeObj(treeId);
var nodes = treeObj.getCheckedNodes(true), //所有选中的节点
ids = [],names = [];
for (var i = 0, l = nodes.length; i < l; i++) {
if (nodes[i].isParent) {//本身是父节点,并且是全选的父节点 则不管子节点
if (nodes[i].getCheckStatus().half) {//半选父节点
} else {//全选节点(本身是父节点) 查看他的父节点是不是全选
var parent = nodes[i].getParentNode();
if (parent == null) {//本身父节点为空 表示是全选根节点 应该存储
ids.push(nodes[i].Id);
names.push(nodes[i].Name);
} else {//判断父节点不为空
if (!parent.getCheckStatus().half) {//半选父节点
} else {
ids.push(nodes[i].Id);
names.push(nodes[i].Name);
}
}
}
} else {//本身是叶子节点 父节点选中,则不存 父节点半选或者不选 则存下来
var parent = nodes[i].getParentNode();
if (parent == null) {//全选叶子节点 父节点为空 即只有一个根节点 保存
ids.push(nodes[i].Id);
names.push(nodes[i].Name);
} else {//全选叶子节点 有父节点
if (parent.getCheckStatus().half) {//父节点半选 存储
ids.push(nodes[i].Id);
names.push(nodes[i].Name);
} else {//父节点全选 不存储
}
}
}
}
var str = "";
if (ids != null && ids.length > 0) {
str = ids[0] ;
for (var i = 1; i < ids.length; i++) {
str += " , " + ids[i] ;
}
}
};
正好找到一篇文章,写的比较全面,如有侵权,联系删除
————————————————
版权声明:本文为CSDN博主「用户147258369」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/hyq_07_27/article/details/110495446