EChart處理三維數據做圖表、多維legend圖例處理


  處理三維數據做圖表,比如返回的數據就是一個個list,list里面某幾個數據同屬於一個維度,項目中的實例效果如下:

  上面的khfx會有多個,比如db1、db2、db3等,下面的那些數據也會變化,目前需求就是做的下面的實現單選,可以使用echarts的legend的selectedMode實現,然后上面的db那些就是可以復選,默認全顯示,選擇之后就取消該條數據顯示。也就是說相當於需要2層圖例組件同時控制下面series的顯示。

  大值考慮的是下面的用legend的圖例,然后上面的圖例就自己手寫,然后通過js方法去實現類似圖例的功能。

  踩坑記錄:

  1、剛開始想的就是通過legend的selected設置為false來達到效果(之前處理翻頁使用過這種),但是發現不行,設置某一個name為false,會影響到上面圖例所有的數據,因為series里的那個name是一樣的,但是這個name又必須和legend里的一一對應,所以放棄

  2、考慮先刪除比如db1的數據,所以先定義一個存儲的數組,來存儲刪除的數據,因為點擊series的線消失,再點擊還是要加進去的,這種實現可以。但是有個問題,就是當刪除series為[]一個空數組時,下面的圖還是會有。在echart的demo里面試一下,發現series:[],不會畫圖

  解決方案:

  當選中上面圖例時,只把series里面的對象的data置為[]空數組,詳情看下面的changeLegrend方法,完美實現效果,代碼還沒優化,碰到類似處理三維圖例的需求時,可以參考下

<template>
    <div>
    <div class="legend_container">
        <ul>
            <li v-for="item in legendData">
                <button class="btn-link btn-legend-item" @click="changeLegrend(item,$event)"><span class="legend-item-bg" :style="'background-color:'+legendColor[item]"></span>{{item}}</button>
            </li>
        </ul>
    </div>
    <div id="myLine" :style="{width:'100%',height:'300px'}"></div>
    </div>
</template>
<script type="ecmascript-6"> import {getPhyLogiLoadApi} from '@/apis' export default { data(){ return { xData:[], series:[], legendData:[], legendColor:{}, storage:{}, colors:['#5793f3', '#d14a61', '#675bba'] } }, methods:{ drawLine(){ let myLine = this.$echarts.init(document.getElementById('myLine')); let option = { tooltip: { trigger: 'axis' }, legend: { selectedMode:'single' }, grid: { left: '3%', right: '7%', bottom: '3%', containLabel: true }, xAxis: [ { type: 'category', axisTick: { alignWithLabel: true }, data: this.xData, name: '快照時間' } ], yAxis: [ { type: 'value', name: '統計值' } ], series: this.series }; myLine.setOption(option); window.addEventListener("resize", () => { myLine.resize();}); }, fetchData(){ getPhyLogiLoadApi(this.$store.state.inspection.reportInfo.batch_id).then((res) => { if(res.status === 200){ let _dataArray = res.data, len = _dataArray.length; for(let i=0;i<len;i++){ if(!this.legendData.includes(_dataArray[i].instance_name)){ this.legendColor[_dataArray[i].instance_name] = this.colors[this.legendData.length]; this.legendData.push(_dataArray[i].instance_name); } let _obj = { name:_dataArray[i].stat_name, type:'line', smooth:true, dbname:_dataArray[i].instance_name, color:this.legendColor[_dataArray[i].instance_name], data:_dataArray[i].stat_value.split(',') } this.series.push(_obj) } this.xData = _dataArray[0].snap_time.split(',') this.drawLine(); } }) }, changeLegrend(item,e){ let _obj = {}, len = this.series.length, _data = this.series; let thisDom = e.currentTarget; thisDom.classList.toggle('btn-selected'); for(let i = 0; i < len; i++){ if(item === _data[i].dbname){ //如果為空,說明被選,置為存儲的數據
                    if(_data[i].data.length === 0){ _data[i].data = this.storage[item][_data[i].name] }else{ //先存數據,再置為空
                        _obj[_data[i].name] = _data[i].data; _data[i].data = [] } } } //存儲數據
            this.storage[item] = _obj; this.drawLine(); } }, mounted(){ this.fetchData(); } } </script>
<style scoped lang="stylus" rel="stylesheet"> .legend_container{ text-align center li { list-style none display inline } } .btn-link, .btn-link:active, .btn-link:focus, .btn-link:hover { border-color: transparent; background-color: transparent; box-shadow: none; } .btn-legend-item { color: rgb(72, 72, 72); padding: 0px; } .legend-item-bg { display:inline-block; width: 20px; height: 12px; margin-right: 5px; border-radius: 2px; } .btn-selected{ opacity 0.3 } </style>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM