jsTree "select_node" 返回 false



我在angularjs中使用jtree,并在"ready"中使用"select_node"。这个方法返回false。在调试过的代码中,可以观察到tree.instance._model。Data没有那个节点所以this。get_node(obj);返回false。(下面是代码片段)

select_node : function (obj, supress_event, prevent_open, e) {
        var dom, t1, t2, th;
        if($.isArray(obj)) {
            obj = obj.slice();
            for(t1 = 0, t2 = obj.length; t1 < t2; t1++) {
                this.select_node(obj[t1], supress_event, prevent_open, e);
            }
            return true;
        }
        obj = this.get_node(obj); //here it returns false
        if(!obj || obj.id === '#') {
            return false;
        }
}

我不确定为什么tree.instance._model。data在那个时候没有数据,因为它经常在我刷新浏览器时工作。

帮忙吗?下面是我的代码片段。

me.onTreeReady = function (eve, tree) {
   tree.instance.deselect_all();
   tree.instance.refresh(true, true);
   var response = tree.instance.select_node(defaultNode); 
}

这必须是与你的angular指令提供商相关的某种竞争条件。

此问题已解决。我已经将"id"添加到html中,所以当创建多个具有相同id的实例时,它会给出上述错误。删除此id已解决此问题。

旧代码

<div class="row no-margin" cg-busy="ctrl.promise">
    <div class="bg-white">
        <div **id="treeView"** js-tree="ctrl.treeConfig"
             should-apply="ctrl.applyModelChanges()"
             ng-model="ctrl.treeData"
             tree="ctrl.treeInstance"
             tree-  events="ready:ctrl.onTreeReadyEvent;select_node:ctrl.onNodeSelectEvent;deselect_node:ctrl.onNodeDeselectEvent">
        </div>
    </div>
</div>
新代码:

<div class="row no-margin" cg-busy="ctrl.promise">
    <div class="bg-white">
        <div js-tree="ctrl.treeConfig"
             should-apply="ctrl.applyModelChanges()"
             ng-model="ctrl.treeData"
             tree="ctrl.treeInstance"
             tree-  events="ready:ctrl.onTreeReadyEvent;select_node:ctrl.onNodeSelectEvent;deselect_node:ctrl.onNodeDeselectEvent">
        </div>
    </div>
</div>

相关内容

  • 没有找到相关文章

最新更新