extjs4 treepanel 动态的加载节点,怎么在选中时,级联选中子节点呢? 5

如上图是一个带checkbox的tree,那么此时"联通测试"下面的子节点们还没有加载,如何实现点击checkbox既加载子节点又级联选中子节点呢?代码参考:onChec... 如上图是一个带checkbox的tree,那么此时"联通测试"下面的子节点们还没有加载,如何实现点击checkbox既加载子节点又级联选中子节点呢?
代码参考:
onCheckboxChange : function(e, t) {
var item = e.getTarget(this.getItemSelector(),this.getTargetEl()), record;
if(item){
record = this.getRecord(item);
var check = !record.get('checked');
record.set( 'checked', check);
if(check) {
record.cascadeBy(function(node) {
node.expand()//此时动态展开,store里面已经有子节点,但是在此处node仍然是参数
//没有子节点的参数,此处应做如何处理,才会刷新node的值
node.set('checked',true);
});
}else{
record.cascadeBy(function( node) {
node.set('checked',false);
});
}
}
}
//*****************************************
当前效果

目的 :让子节点也级联选中。
再顶下,大家过来帮吧
展开
 我来答
xiii130
2013-11-26 · 知道合伙人软件行家
xiii130
知道合伙人软件行家
采纳数:817 获赞数:2867
爱好编程,在工作中积累了比较丰富的经验。愿与大家共同进步。

向TA提问 私信TA
展开全部
Ext.create('Ext.tree.Panel', {
  //添加监听事件
  listeners: {
    checkchange: function(node, state) { 
    //如果被勾选的节点有子节点,则将其子节点全部改为根节点状态
      if (node.hasChildNodes()) {
        for (var j = 0; j < node.childNodes.length; j++) {
            node.childNodes[j].set('checked', state);
        }
      }
    }
});
追问
哥们儿,问题现在节点是动态加载的 ,你点击的时候它还没有children呢,你懂不?展开之后再点击才有children也就是,你必须要先点击+号展开(动态加载子节点后)然后再选择,现在问题是想点击checkbox就直接展开带加载子节点并且选中!
追答
动态加载节点,是在click事件里边进行了一次ajax请求是吧

现在,你在checkchange里边也加一个ajax请求啊

请求成功之后,你把回来的节点的checked全部改成选中或未选中就可以了
网易云信
2023-12-06 广告
UIkit是一套轻量级、模块化且易于使用的开源UI组件库,由YOOtheme团队开发。它提供了丰富的界面元素,包括按钮、表单、表格、对话框、滑块、下拉菜单、选项卡等等,适用于各种类型的网站和应用程序。UIkit还支持响应式设计,可以根据不同... 点击进入详情页
本回答由网易云信提供
xueggping
2014-12-24
知道答主
回答量:1
采纳率:0%
帮助的人:1299
展开全部
onCheckboxChange : function(e, t) {
var item = e.getTarget(this.getItemSelector(), this.getTargetEl()), record;
if (item){
record = this.getRecord(item);
var check = !record.get('checked');
record.set('checked', check);
if (check) {
record.bubble(function(parentNode) {
if(!parentNode.isRoot()){
parentNode.set('checked', true);
}
//parentNode.expand(false, true);
});
record.cascadeBy(function(node) {
if(!node.isRoot()){
node.set('checked', true);
}
//node.expand(false, true);
});
} else {
record.cascadeBy(function(node) {
node.set('checked', false);
});
}
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式