首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >jstree :如何从jsTree中获取所有节点?

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

Stack Overflow用户
提问于 2012-04-24 10:47:49
回答 5查看 30.4K关注 0票数 13

如何获取jsTree中的所有节点?

我正在使用xml构建jsTree。

代码语言:javascript
复制
Root
     -----A
          -----A1
               -----A1.1
               -----A1.2
          -----A2
               -----`A2.1`
               -----A2.2

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

     -----C
          -----C1
               -----C1.1
               -----C2.2

我希望jsTree中所有节点(ID)的数组如下所示

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

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2012-04-27 05:58:35

解决方案,示例:)

代码语言:javascript
复制
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();

xmlString =

代码语言:javascript
复制
<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>

输出:根、A、A1、A1.1、A1.2、A2、A2.1、A2.2、B、B1、B2、C、C1、C1.1、C2.2

:)

票数 6
EN

Stack Overflow用户

发布于 2012-04-24 12:12:40

来自documentation

.get_json ( node , li_attr , a_attr )

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

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

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

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

只要搜索,你就会找到!:)

票数 15
EN

Stack Overflow用户

发布于 2017-08-08 07:42:12

您可以遍历每个节点元素,并通过以下方法将它的id放在数组中:

代码语言:javascript
复制
var idList = [];
var jsonNodes = $('#tree').jstree(true).get_json('#', { flat: true });
$.each(jsonNodes, function (i, val) {
    idList.push($(val).attr('id'));
})
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10296410

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档