jsTree 选中节点异步加载数据

实现效果如下: 

实现效果

依赖引入可以参考jsTree 文档

代码示例:

// template
// <div id="data-block-tree"></div>

// script
const treeData = [
    {
        id: "string" // required
        parent: "string" // required
        text: "string" // node text
        icon: "string" // string for custom
        state: {
            opened: false // is the node open
            disabled: false  // is the node disabled
            selected: false  // is the node selected
        }
    }
]

// ajax 请求
// ...

// 构造jstree
$('#data-block-tree').jstree({
    'core': {
        'check_callback': true,
        "data": function (obj, callback) {
       
            if (treeData.length) {
                callback.call(this, treeData);
            } else {
                $("#data-block-tree").html("暂无数据");
            }
        }
    },
    "plugins": ["sort"]
}).bind("select_node.jstree", function (event, data) {
    // 获取选中的节点
    const inst = data.instance;
    const selectedNode = inst.get_node(data.selected);
    // 加载子节点
    loadDepChild(inst, selectedNode)
});

function loadDepChild(inst, selectedNode) {

    $.ajax({
        url: '',
        dataType: "json",
        type: 'GET',
        contentType: "application/json",
    }).done(function (res, status, xhr) {

        if (res.code === 200) {
            selectedNode.children = [];
            res.data.forEach(item => inst.create_node(selectedNode, item, "last"))
            inst.open_node(selectedNode);
        }
    });
}

参考:jsTree------树形结构--点击节点异步加载数据(在节点上加载数据,而不是tree全面刷新数据)_51CTO博客_el-tree展开指定节点

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值