ExtJs Tree 动态让tree复选框匹配选中功能
我用extJs做了个带复选框的用户tree,现在我做了一个修改用户组的用户的功能,我现在点击用户组的时候,怎么让所属用户组的已有用户前面的复选框自动选上。比如用户一共有五...
我用extJs 做了个带复选框的用户tree,现在我做了一个修改用户组的用户的功能,我现在点击用户组的时候,怎么让所属用户组的已有用户前面的复选框自动选上。
比如用户一共有五个人,但是我当前用户组里面只有其中的三个,我想让这三个用户的复选框自动选中!我已经得到了三个用户的id,怎么与tree里面的用户匹配选中 展开
比如用户一共有五个人,但是我当前用户组里面只有其中的三个,我想让这三个用户的复选框自动选中!我已经得到了三个用户的id,怎么与tree里面的用户匹配选中 展开
2个回答
展开全部
在treepanel里加个
listeners : {
click : function() {
//在这里面判断是否选择了组,如果选中了,则把其下的用户都选中
//比如,判断用户组可以采用判断parentNode来判断是否选的是组。判断是否是用户可以用leaf来判断。
//然后判断这时的点击是选中还是取消选中
//确定选择的是组后,用组的节点对象调用childNodes获取的是下属用户的节点对象,然后进行循环,将他们的checked属性改成true,选中状态(childNodes[i].getUI().checkbox.checked = true; )。或者全部false,取消选中。或者你有用户的id,直接用id获取node对象也可。
}
}
大概是这意思,具体的方法使用你可以查找下api,自己试着改吧
如果不会改,把代码贴上来,hi我下,我有空帮你改
listeners : {
click : function() {
//在这里面判断是否选择了组,如果选中了,则把其下的用户都选中
//比如,判断用户组可以采用判断parentNode来判断是否选的是组。判断是否是用户可以用leaf来判断。
//然后判断这时的点击是选中还是取消选中
//确定选择的是组后,用组的节点对象调用childNodes获取的是下属用户的节点对象,然后进行循环,将他们的checked属性改成true,选中状态(childNodes[i].getUI().checkbox.checked = true; )。或者全部false,取消选中。或者你有用户的id,直接用id获取node对象也可。
}
}
大概是这意思,具体的方法使用你可以查找下api,自己试着改吧
如果不会改,把代码贴上来,hi我下,我有空帮你改
推荐于2017-09-29 · 知道合伙人数码行家
可以叫我表哥
知道合伙人数码行家
向TA提问 私信TA
知道合伙人数码行家
采纳数:25897
获赞数:1464984
2010年毕业于北京化工大学北方学院计算机科学与技术专业毕业,学士学位,工程电子技术行业4年从业经验。
向TA提问 私信TA
关注
展开全部
获取tree的选中值方法:var nodes = tree.getChecked();
当点击父级节点同时选中子节点方法:
需要添加“checkchange”事件。
"checkchange": function(node, state) {
if (node.hasChildNodes()) {
for (i = 0; i < node.childNodes.length; i++) {
node.childNodes[i].getUI().checkbox.checked = state;
}
}
}
递归所有节点:
"checkchange": function(node, state) {
if (node.hasChildNodes()) {
node.eachChild(function(child) {
child.ui.toggleCheck(state);
child.attributes.checked = state;
child.fireEvent('checkchange', child, state); //递归调用
});
}
当点击父级节点同时选中子节点方法:
需要添加“checkchange”事件。
"checkchange": function(node, state) {
if (node.hasChildNodes()) {
for (i = 0; i < node.childNodes.length; i++) {
node.childNodes[i].getUI().checkbox.checked = state;
}
}
}
递归所有节点:
"checkchange": function(node, state) {
if (node.hasChildNodes()) {
node.eachChild(function(child) {
child.ui.toggleCheck(state);
child.attributes.checked = state;
child.fireEvent('checkchange', child, state); //递归调用
});
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询