#为什么会最终会选择树图
在长达三天尝试,根据图的要求,第一次选择了echarts的关系图,但是在做的过程中就出现了问题,首先我选择的是坐标生成位置,由于后端返的数据不是固定的而且两条关系中必然有相同的名称,这个关系图就很符合当时我要做的效果,但是source,target的指向不可以重复,当关系复杂时而且再保证看的不乱的情况下,这种是不符合我的要求的,加上它的坐标生成的位置,对于我的数据来说不太好动态生成。
#为什么是最终选择树图,那你第二次选的什么
当这个不好生成之后,就开始另谋他路,Relation Graph在这个上面我看到了很多不一样的demo,虽然demo多多,但是找到符合的还是很少,其中一个尝试之后,还是跟上一个的选择的问题有些相似之处的,这是它的在线配置工具
#选择echarts的树图之后,具体步骤能说么
这个当然可以,下面的代码相信大家都会放对位置的,就不再过多叙述了
<div class="chartbox" id="chartbox">
<div :style="{height:chartHeight+ 'px'}" id="ass"> </div>
</div>
chartHeight:1200,
.chartbox{
overflow-y: auto;
overflow-x: hidden;
height: 900px;
}
getData(){ // 获取后端的数据并处理
this.$request // 这里是在全局中配置了
.post('地址',{})
.then((res)=>{
this.datas = res.data
this.tree_data = {
name: "噜啦嘞",
children: [],
value:'0',
// symbol 是需要在每一个包含children的中去单独配置的,只在series中配置不生效
// symbol的图片的生成的方法写最后
symbol: "image://"
};
var temp ={}
for (var key in this.datas) {
this.datas[key].children = [];
this.datas[key].children.push({
name: this.datas[key].dName,
children: [],
value:'0',
symbol: "image://"
});
this.datas[key].children.forEach((i, ik) => {
this.datas[key].moList.forEach((direItem) => {
this.datas[key].children[ik].children.push({
name: direItem.aName,
children:[],
value:'0',
symbol: "image://"
})
direItem.oiList.forEach((oils)=>{
temp = { name: oils.otName, children: [],value:'1',
symbol: "image://"};
oils.oList.forEach((oilDep)=>{
temp.children.push({
name:oilDep.otwoName,
children:[],
value:'1',
symbol: "image://"
})
oilDep.reList.forEach((ref)=>{
temp.children[ik].children.push({
name:ref.reName,
symbolSize: 1, // 无children的设置为1,不显示节点
})
})
oilDep.oiList.forEach((gaso)=>{
temp.children[ik].children.push({
name:gaso.gName,
symbolSize: 1,
label: {
position: "right",
verticalAlign: "middle",
align: "left",
color: "#BDBDBD",
fontSize: 24,
},
})
})
})
oils.oiOList.forEach((gas)=>{
temp.children.push({
name:gas.gName,
symbolSize: 1,
label: {
position: "right",
verticalAlign: "middle",
align: "left",
color: "#BDBDBD",
fontSize: 24,
},
})
})
})
this.datas[key].children[0].children.forEach((te)=>{
te.children.push(temp)
})
});
this.tree_data.children.push(this.datas[key].children[ik]);
});
}
this.tree_data.children.forEach((item)=>{
item.children.forEach((itc)=>{
if(itc.children.length>1){
itc.children = itc.children.splice(0,1)
console.log(itc);
}
})
})
var series = [];
var tooltip = [];
tooltip.push({
trigger: "item",
triggerOn: "mousemove",
});
series.push({
type: "tree",
id: 0,
name: "tree1",
data: [this.tree_data],
top: "8%",
left: "5%",
bottom: "22%",
right: "20%",
symbolSize: 20,
symbol: "emptyCircle", //设置图形的形状
edgeShape: "polyline",//折线,curve 曲线
edgeForkPosition: "63%",
initialTreeDepth: 3,
height:'1000px',
with:'100%',
lineStyle: {
width: 3,
},
itemStyle: {
borderColor: "#60e4fb", //图形的边框颜色
color: "#60e4fb", //图形的填充颜色
},
label: {
position: "left",
verticalAlign: "middle",
align: "right",
borderColor: "#F56C6C",
color: "#fff",
fontSize: 24,
fontWeight: "bold",
},
leaves: {
label: {
position: "right",
verticalAlign: "middle",
align: "left",
color: "#fff",
fontSize: 24,
},
},
emphasis: {
focus: "descendant",
},
expandAndCollapse: true,
animationDuration: 550,
animationDurationUpdate: 750,
});
this.sendingChart(tooltip, series);//请求到数据并处理之后调用
})
},
sendingChart(tooltip, series) {
this.$echarts.init(document.getElementById("ass")).dispose();
var myChart = this.$echarts.init(document.getElementById("ass"));
var option = {
tooltip: tooltip,
series: series,
};
option && myChart.setOption(option);
myChart.on('click',(param)=>{
if(param.data.value=="0"){
param.data.symbol= "image://"
param.data.value="1"
myChart.resize();
}else{
param.data.symbol='image://'
param.data.value="0"
myChart.resize();
}
});
// 这里是滚动条的前提,让子节点数据过多时不挤一块,
const eleArr = Array.from(new Set(myChart._chartsViews[0]._data._graphicEls))
const itemHeight = 50
const currentHeight = itemHeight * (eleArr.length-1) || itemHeight
const newHeight = Math.max(currentHeight,itemHeight)
this.chartHeight = newHeight
myChart.resize({
height:newHeight
})
document.getElementById("chartbox").scrollTop = (newHeight/2)-900
},
#效果图,滚动条让我遮住了…
滚动条的样式我是处理过的
#有什么要注意的
首先是symbol的图片生成,在官网找到tree下的symbol,点击试一试,上传本地图片,看下图所示,复制即可;
其次就是点击节点图片变化,前提你得准备两张图myChart.resize();得加这个属性,不然不会生效,还有就是不能在在children中push自定义的值,本人测试过,一直报错,所以用value来代替,写成固定值,点击之后变换值,再替换图片;
最后就是代码中不要直接复制粘贴,找到核心的且有用的,再复制。
#end…
本期到此结束,这里是能学一点是一点,如有疑问欢迎留言,如有致电,请拨打电话,如没关注,请不用关注…