23

我正在尝试编写一个在 jsTree 上打开特定节点的函数,但是我遇到了一个问题,即在从 ajax 调用加载我的基树之前执行该函数。如何判断我的 jstree 数据是否已加载并等待加载完成。以下是我尝试使用的功能。

function openNodes(tree, nodes) {
    for (i in nodes) {
        $('#navigation').jstree("open_node", $(nodes[i]));
    }
}

我正在使用以下命令加载我的初始树

$("#navigation").jstree({
    "json_data": {
        "ajax": {
            "url": function(node) {
                var url;
                if (node == -1) {
                    url = "@Url.Action("BaseTreeItems", "Part")";
                } else {
                    url = node.attr('ajax');
                }
                return url;
            },
            "dataType": "text json",
            "contentType": "application/json charset=utf-8",
            "data": function(n) { return { id: n.attr ? n.attr("id") : 0, ajax: n.attr ? n.attr("ajax") : 0 }; },
            "success": function() {
            }
        }
    },
    "themes": { "theme": "classic" },
    "plugins": ["themes", "json_data", "ui"]
});
4

8 回答 8

35

在对元素调用 .jstree() 之前,可以将回调绑定到before.jstree事件loaded.jstree

$(selector)
.bind('before.jstree', function(e, data) {
    // invoked before jstree starts loading
})
.bind('loaded.jstree', function(e, data) {
    // invoked after jstree has loaded
    $(this).jstree("open_node", $(nodes[i]));
})
.jstree( ... )
于 2012-07-12T12:57:06.997 回答
15

在较新版本的 jstree 中,您可能需要等到所有节点都完成加载后才能与它们交互。为此,您需要:

ready.jstree

所以:

$(selector)
    .bind('ready.jstree', function(e, data) {
        // invoked after jstree has loaded
     })
...
于 2014-11-12T20:19:09.697 回答
7

我使用了 setInterval 和 clearInterval:

var interval_id = setInterval(function(){
     // $("li#"+id).length will be zero until the node is loaded
     if($("li#"+id).length != 0){
         // "exit" the interval loop with clearInterval command
         clearInterval(interval_id)
         // since the node is loaded, now we can open it without an error
         $("#tree").jstree("open_node", $("li#"+id))
      }
}, 5);

JStree 的“.loaded”回调只对根节点有效;“._is_loaded”可能会起作用,而不是检查节点的长度,但我还没有尝试过。无论哪种方式,动画设置都会导致树中较深的节点在几毫秒后加载。setInterval 命令创建一个定时循环,在加载所需节点时退出。

于 2012-12-17T21:20:56.123 回答
4

你最好先调用 $.ajax() 函数来获取你想要的数据,你可以在 success: 字段中调用 $().jstree() 函数,就像我的代码一样。

    var fullTree;
$.ajax({
  url :"./php/select_tree.php",
  data : fullTree,
  method : "GET",
  dataType : "json",
  success : function(fullTree){
    $("#jstree").jstree({
      "core" : {
        "data" :fullTree,
        "check_callback" : true
       },
       "plugins" : [ "contextmenu", "dnd", "changed", "wholerow" ]
    });
  }
})
;
于 2015-09-26T16:08:27.800 回答
3

我在我的情况下使用refresh.jstree事件(我需要经常动态更改和刷新 jstree 中的节点)。

根据文档,它

刷新调用完成时触发

jsTree 文档(事件)

示例代码:

$.post( [url], ... ).done(function(){ $jstree.jstree().settings.core.data = result; $jstree.jstree().refresh(); }); $(selector).on('refresh.jstree', function(){ // do something });

于 2019-01-04T08:54:08.243 回答
2

[免责声明:这不适用于 OP,因为状态插件未在设置代码中列出。]

如果您使用状态插件,请使用 state_ready.jstree 事件而不是 ready.jstree 或 loaded.jstree 事件。

$(selector).on('state_ready.jstree', function () {
    // open desired node
})
于 2018-09-24T16:04:06.233 回答
1

您不必添加间隔。该插件在通过 ajax 加载的节点上设置一个类。

.one("reselect.jstree", function (evt, data) {
        if ($("#MYTREEID").find(".jstree-loading").length == 0) {
            alert('my ajax tree is done loading");
        }
    })
于 2013-09-24T14:09:38.670 回答
0

由于我没有找到解决方案,这适用于当前版本的 JSTree (3.3.7) 我将在这里发布我的工作方法。

首先,我在 select_node 上绑定并告诉 jstree 打开父节点,每当我选择 i 节点时。

var strIdentifierJsTree  = "#your-whatever-id-to-jstree";
var strNode2Select = "#your-whatever-id-to-your-node-which-parents-has-to-be-showed";

$( strIdentifierJsTree ).on("select_node.jstree", function (e, data) {
       $(strIdentifierJsTree).jstree(true).open_node( data.node.parent );
});

然后我绑定到加载功能:

$( strIdentifierJsTree ).bind('loaded.jstree', function(e, data) {
       $(strIdentifierJsTree).jstree(true).select_node( strNode2Select );
});

现在它将在 JSTree 初始化后(完全加载时)选择我的节点,并打开所有父节点,无论嵌套深度如何。像其他答案中提到的那样,单个开放节点方法对我不起作用。

于 2021-06-30T22:57:30.613 回答