![](/img/trans.png)
[英]How do I programmatically select a node in jsTree and open all parents
[英]JSTree Select Open Node
我对 JSTree 有疑问。
我正在用数据库中的数据填充所选项目。 但我希望我选择的项目在填充后自动打开。 我不能做自动打开的部分。
我在页面上添加了一个按钮(btn_test)。 我在这个按钮的点击事件中写了以下内容。
$("#TreeElement").jstree("toggle_node","#34B526D0-1E2C-4170-829E-1995782DB831");
当我点击 btn_test 按钮时,其 ID 被写入的节点打开和关闭。 但是我无法将其设置为在选择和填充相应节点时自动打开。
$("#btn_test").click(function () {
$("#TreeElement").jstree("toggle_node","#34B526D0-1E2C-4170-829E-1995782DB831");
});
JS端如下;
var TreeElement = $("#TreeElement");
TreeElement.jstree({
"core" : {
"check_callback" : true
},
state : { "opened" : true }
});
TreeElement.bind("select_node.jstree", function (e, data) {
GetSelectedElementChildrenNodes(data.node.id);
});
function GetSelectedElementChildrenNodes(SelectedNodeId) {
$.getJSON('http://serveripadress/api/browser.php?getchildren='+SelectedNodeId,function (data) {
$.each(data,function (index,element) {
TreeElement.jstree().create_node(SelectedNodeId
, { "id" : element.nodeid, "text" : element.nodename}, "last");
TreeElement.jstree(true).set_icon(element.nodeid,element.icon);
});
});
}
当我如下更改代码时,我得到了不同的结果。 我点击Node1,里面填满了相关数据,但是打不开,然后我点击Node2,但是node1正在打开:)
TreeElement.bind("select_node.jstree", function (e, data) {
GetSelectedElementChildrenNodes(data.node.id);
$("#"+data.node.id).jstree("open_all");
});
我一直在更改代码一段时间,但我无法让它工作。 如果有人可以帮助我,我真的很感谢他。
太感谢了!
问题解决了。
在我使用 Json 提取数据的 function 中,我将以下代码添加到 getJson 的末尾。
TreeElement.jstree("toggle_node",NodeId);
function的新state如下;
function GetSelectedElementChildrenNodes(SelectedNodeId) {
$.getJSON('http://serveripadress/api/browser.php?getchildren='+SelectedNodeId,function (data) {
$.each(data,function (index,element) {
TreeElement.jstree().create_node(SelectedNodeId
, { "id" : element.nodeid, "text" : element.nodename}, "last");
TreeElement.jstree(true).set_icon(element.nodeid,element.icon);
});
TreeElement.jstree("toggle_node",NodeId);
});
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.