先来看一下实现效果:
图表难点在于节点上的加减号、节点的点击事件、节点的文字样式的格式化等。
上代码:
getchartnewTwo(id, chartData) { let myChart = echarts.init(document.getElementById(id)) let newData = this.handleData(chartData) // console.log('最终数据', newData) let option = { tooltip: { trigger: 'item', triggerOn: 'mousemove', formatter: (params) => { // console.log('悬浮窗样式', params) let str = `${params.data.name} ${params.data.value}` return str }, textStyle: { color: '#fff', fontSize: 36, }, backgroundColor: '#041b34', borderColor: '#035693', borderWidth: 8, padding: [20, 30, 20, 30] }, dataZoom: { type: 'inside' }, series: [{ type: "tree", roam: true, // silent: true, // initialTreeDepth: -1, initialTreeDepth: 1, data: newData, top: "0%", left: "20%", bottom: "0%", right: "0%", symbolSize: 50, zoom: 0.8, edgeShape: "polyline", //链接线是折现还是曲线 symbol: (value, params) => { // console.log('图标', params) let icon = '' if (params.data.children.length < 1) { icon = '' } else if (params.collapsed) { icon = `image://` } else if (!params.collapsed) { icon = `image://` } return icon }, itemStyle: { color: 'rgba(255,255,255,0)', // padding: 20, // 节点之间的间距 // borderWidth: 13, // borderColor: '#0091FF' }, symbolOffset: [20, 0], label: { normal: { position: 'left', verticalAlign: 'middle', // align: 'center', // align: 'left', distance: -2, // distance: -20, overflow: 'truncate', ellipsis: '...', color: '#fff', formatter: (params) => { let str = `${params.data.name} ${params.data.value == 0 ? '' : params.data.value}` if (str.length > 8) { str = str.slice(0, 8) + '...' } let menu = `{d|${str}}` if (params.data.ldlx == '断链') { menu = `{a|${str}}` } else if (params.data.ldlx == '弱链') { menu = `{b|${str}}` } else if (params.data.ldlx == '强链') { menu = `{c|${str}}` } return menu }, rich: { a: { fontSize: 36, width: 360, height: 80, // padding: [20, 30, 20, 30], color: '#fff', align: 'middle', // backgroundColor: 'rgba(240, 96, 96, .3)', backgroundColor: '#492c42', borderRadius: 10, overflow: 'truncate', ellipsis: '...', borderWidth: 3, // borderColor: 'rgba(240, 96, 96, 1)' borderColor: '#e85e5f' }, b: { fontSize: 36, width: 360, height: 80, // padding: [20, 30, 20, 30], color: '#fff', align: 'middle', // backgroundColor: 'rgba(0, 145, 255, .3)', backgroundColor: '#04457c', borderRadius: 10, overflow: 'truncate', ellipsis: '...', borderWidth: 3, // borderColor: 'rgba(0, 145, 255, 1)' borderColor: '#026dc1' }, c: { fontSize: 36, width: 360, height: 80, // padding: [20, 30, 20, 30], color: '#fff', align: 'middle', // backgroundColor: 'rgba(19, 194, 194, .3)', backgroundColor: '#095269', borderRadius: 10, overflow: 'truncate', ellipsis: '...', borderWidth: 3, // borderColor: 'rgba(19, 194, 194, 1)' borderColor: '#11aaaf' }, d: { fontSize: 36, width: 360, height: 80, // padding: [20, 30, 20, 30], color: '#fff', align: 'middle', backgroundColor: '#395372', borderRadius: 10, overflow: 'truncate', ellipsis: '...', borderWidth: 3, borderColor: '#bad3ff' } } } }, lineStyle: { color: 'rgba(255, 255, 255, .5)', width: 5, curveness: 0.5, }, expandAndCollapse: true, animationDuration: 550, animationDurationUpdate: 750, }] } myChart.setOption(option) myChart.on('mousedown', (e) => { // console.log('鼠标下', e) const name = e.data.name const nodeList = myChart._chartsViews[0]._data.tree._nodes const curNode = nodeList.filter(item => { return item.name === name && item.children.length == e.data.children.length }) // console.log('鼠标下', name, curNode) const dataIndex = curNode[0].dataIndex const curIsExpand = JSON.parse(JSON.stringify(curNode[0].isExpand)) if (e.event.topTarget.style.text) { // console.log('点击了label', dataIndex, curIsExpand) nodeList.forEach(item => { if (item.dataIndex == dataIndex && item.name == name && !curIsExpand) { // console.log('走这里吗', item) item.isExpand = true } else if (item.dataIndex == dataIndex && item.name == name && curIsExpand) { // console.log('走这里吗222', item) item.isExpand = false } }) this.queryQyList(name) } }) },
复制