jsTree:如何从jstree获取所有节点?

Sta*_*low 12 javascript jquery jquery-plugins jquery-selectors jstree

如何让所有节点都出现在jsTree中?

我正在用xml构建jsTree

Root
     -----A
          -----A1
               -----A1.1
               -----A1.2
          -----A2
               -----`A2.1`
               -----A2.2

     -----B
          -----B1
          -----B2

     -----C
          -----C1
               -----C1.1
               -----C2.2
Run Code Online (Sandbox Code Playgroud)

我想要jsTree中存在的所有节点(ID)的数组如下

预期产出:[Root,A,A1,A1.1,A1.2,A2,A2.1,A2.2,B,B1,B2,C,C1,C1.1,C2.2]

mon*_*ist 14

来自文档:

.get_json ( node , li_attr , a_attr )

此函数返回转换回JSON的树节点数组.

有关此doc的相同功能的更多信息:

此函数遍历整个树并将其导出为JSON.请参阅数据源部分以查看输出的格式.

如果将节点指定为第一个参数,则导出中仅包含该节点及其子节点,否则将导出整个树.

只是搜索,你会发现!:)


Sta*_*low 6

解决方案示例:)

var xmlString = $("#tree").jstree("get_xml");   
    var xmlDOM = $.parseXML(xmlString);

    var IDList =[];
var items = $(xmlDOM).find('root item');
$.each (items, function(key, val){
    IDList.push($(val).attr('id'));
})

IDList.pop();
Run Code Online (Sandbox Code Playgroud)

xmlString =

<root>  
        <item id="A" parent_id="0" state="close">  
            <content><name>Charles Madigen</name></content>                
        </item>
        <item id="A1" parent_id="A" state="close">  
            <content><name>Charles Madigen</name></content>                
        </item>
          .
          .
</root>
Run Code Online (Sandbox Code Playgroud)

输出:Root,A,A1,A1.1,A1.2,A2,A2.1,A2.2,B,B1,B2,C,C1,C1.1,C2.2

:)


MDu*_*mmy 5

您可以遍历每个节点元素并将其 id 放入数组中:

var idList = [];
var jsonNodes = $('#tree').jstree(true).get_json('#', { flat: true });
$.each(jsonNodes, function (i, val) {
    idList.push($(val).attr('id'));
})
Run Code Online (Sandbox Code Playgroud)