树图,用不同图片表示节点折叠和展开状态echarts ').join("\n"); return name; } } }, leaves: { label: { normal: { position: "bottom", verticalAlign: "top", align: "center", distance: 10 } } } }] }; // 原始数据 const originalData = { 1: { name: '百度在线网络技术(北京)有限公司配置项内容和展示

官方暂不支持,上传两张图片分别表示节点折叠和展开两种状态,这里给出了自己的实现方式

配置项如下
      // 这里我选的图片是透明背景的,如果使用白色背景的图片就可以遮盖节点后的线条了
let plusImg = "";

let minusImg = "";

let emptyImg = ''

// 获取节点显示的图片
const getSymbolImg = (item = {}) => {
    return `image://${item.children && item.children.length ? minusImg : item.children_bak && item.children_bak.length ? plusImg : emptyImg}`;
};

// 基础配置option
const commonOption = {
    tooltip: {
        trigger: "item",
        triggerOn: "mousemove",
        enterable: true,
        alwaysShowContent: false,
        hideDelay: 100,
        formatter: '{b}'
    },
    animation: false,
    series: [{
        type: "tree",
        symbolSize: 30,
        symbol: "emptyCircle",
        left: "2%",
        right: "2%",
        top: 60,
        bottom: 170,
        orient: "vertical",
        expandAndCollapse: true,
        initialTreeDepth: -1,
        label: {
            normal: {
                position: "top",
                verticalAlign: "bottom",
                align: "center",
                fontSize: 12,
                formatter: param => {
                    let name = param.data.name;
                    if (name.length >= 10) {
                        name = name.slice(0, 9) + "...";
                    }
                    name = name.split('').join("\n");
                    return name;
                }
            }
        },
        leaves: {
            label: {
                normal: {
                    position: "bottom",
                    verticalAlign: "top",
                    align: "center",
                    distance: 10
                }
            }
        }
    }]
};

// 原始数据
const originalData = {
    1: {
        name: '百度在线网络技术(北京)有限公司',
        id: 1,
        level: 0
    },
    2: {
        id: 2,
        name: '产品部',
        level: 1,
        parent_node_id: 1
    },
    3: {
        id: 3,
        name: '研发部',
        level: 1,
        parent_node_id: 1
    },
    4: {
        id: 4,
        name: '前端开发',
        level: 2,
        parent_node_id: 3
    },
    5: {
        id: 5,
        name: '后端开发',
        level: 2,
        parent_node_id: 3
    },
    6: {
        id: 6,
        name: '算法',
        level: 2,
        parent_node_id: 3
    },
    7: {
        id: 7,
        name: '测试部',
        level: 2,
        parent_node_id: 3
    },
    8: {
        id: 8,
        name: '运维',
        level: 2,
        parent_node_id: 3
    },
    9: {
        id: 9,
        name: '运营',
        level: 1,
        parent_node_id: 1
    },
    10: {
        id: 10,
        name: '运营-1部',
        level: 2,
        parent_node_id: 9
    },
    11: {
        id: 11,
        name: '运营-2部',
        level: 2,
        parent_node_id: 9
    },
    12: {
        id: 12,
        name: '产品-1部',
        level: 2,
        parent_node_id: 2
    },
    13: {
        id: 13,
        name: '产品-2部',
        level: 2,
        parent_node_id: 2
    },
}


// 数据处理
const innerData = [];
Object.values(originalData).forEach((item, index) => {
    if (innerData[item.level] && innerData[item.level].length) {
        innerData[item.level].push(item);
    } else {
        innerData[item.level] = [item];
    }
});

for (let i = innerData.length - 1; i >= 0; i--) {
    // 每个item和result中的每个对象是同一引用
    innerData[i].forEach((item, index, all) => {
        item.close = function(state) {
            if (this.children) {
                if (this.children_bak.length) {
                    if (state === true || this.children.length) {
                        this.children = [];
                        this.children_bak.forEach((child) => {
                            child.close(true)
                        })
                    } else {
                        this.children = this.children_bak
                    }
                    this.symbol = getSymbolImg(this)
                }
                
            }
        }
        if (i !== innerData.length - 1) {
            item.children = [];
            item.children_bak = [];
            item.add = function(it) {
                if (!!it) {
                    this.children.push(it);
                    this.children_bak.push(it);
                }

            }
            innerData[i + 1].forEach((child) => {
                if (+child.parent_node_id === +item.id) {
                    item.add(child)
                }
            })
        }
        if (i === 0) {
            item.label = {
                normal: {
                    rotate: 0,
                    align: "center",
                    formatter: "{b}"
                }
            };
        }
        item.symbol = getSymbolImg(item);
    });
}


// 单个节点的点击事件
const clickFun = param => {
    //因为保存了对象同一引用,所以可以使用originalData快速找到目标对象
    let aimObj = originalData[param.data.id];
    // 组合模式实现关闭开启
    aimObj.close()
    // 手动关闭tooltip不然会出现不可关闭的tooltip
    myChart.dispatchAction({
        type: "hideTip"
    });
    myChart.clear();
    commonOption.series[0].data = innerData[0]

    myChart.setOption(
        commonOption,
        true
    );
};

commonOption.series[0].data = innerData[0];
myChart.setOption(
    commonOption,
    true
)

myChart.on("click", clickFun);
    
截图如下