在Vue中使用Echarts可視化庫(kù)的完整步驟記錄
前言
由于最近項(xiàng)目需要做可視化數(shù)據(jù)展示,也就是用圖表展示數(shù)據(jù),他還有一個(gè)很高端的名字:“大數(shù)據(jù)可視化”(參考圖一),首先考慮選擇什么圖表庫(kù)來(lái)作為基礎(chǔ)開發(fā),目前被普遍認(rèn)可的是Hcharts、Echarts、AntV。
介紹:
Hcharts:國(guó)外的一款圖表庫(kù),是圖表庫(kù)的領(lǐng)頭羊
Echarts:百度開發(fā)的數(shù)據(jù)可視化庫(kù),國(guó)內(nèi)圖表庫(kù)的 “領(lǐng)軍人物”
AntV:是螞蟻金服開發(fā)的數(shù)據(jù)可視化庫(kù)
總結(jié)出以下幾個(gè)優(yōu)略點(diǎn)區(qū)別Echarts、Hcharts哪個(gè)比較合適:
1、學(xué)習(xí)容易程度:只要懂JS,那么相信你能很快上手。兩者打分相同。但是百度出品的Echarts對(duì)于國(guó)內(nèi)城市已經(jīng)有了相應(yīng)的配置,調(diào)用非常方便。因此在繪制地圖方面,Echarts略勝一籌。
2、大數(shù)據(jù)表現(xiàn)力:有網(wǎng)友說,當(dāng)數(shù)據(jù)量達(dá)到萬(wàn)條的級(jí)別時(shí),Highcharts的多表聯(lián)動(dòng)、自動(dòng)縮放具有更強(qiáng)的優(yōu)勢(shì),而Echarts則會(huì)出現(xiàn)明顯的卡頓,需要設(shè)置datazoom。因此Hcharts完勝。
3、文檔友好程度:Echarts是百度的,Hcharts是國(guó)外的。另外,Echarts的文檔像是說明書,而Highcharts的文檔像是博客。個(gè)人仍偏向于說明書一樣的文檔,容易定位,因此我為Echarts轉(zhuǎn)身亮燈。
4、圖表美觀程度:看看兩家的實(shí)例Echarts、Hcharts,Echarts完爆??!而且Echarts基于Canvas,對(duì)于3D繪圖有絕對(duì)優(yōu)勢(shì),能畫出極漂亮的圖形。
5、圖表配置的自由度:Hcharts基于SVG,方便定制,同類型的圖表,Hcharts能玩出100種花樣。
6、圖表的豐富程度:Echarts豐富的圖表種類,和驚艷的3D效果,吊打Hcharts。
最后,更為關(guān)鍵的是,Echarts免費(fèi),Hcharts用于商業(yè)用途時(shí)還需要授權(quán),個(gè)人用時(shí)雖然免費(fèi),但會(huì)在圖表上顯示logo,有潔癖的話就只能繞道了。
所以,就決定是你了,Echarts!
個(gè)人不推薦使用Vue-Echarts版本,因?yàn)镋charts本身難度不算大,雖然文檔有點(diǎn)像是 “說明書”,但是還算全乎,花點(diǎn)時(shí)間還是可以理解的。
引入:
在Vue中使用Echarts時(shí)可以按照一般引入插件的方式引入
1、使用npm安裝Echarts:
npm install echarts --save
2、全局引入Echarts:
//main.js 不推薦 import echarts from "echarts"; Vue.prototype.$echarts = echarts;
個(gè)人不推薦在main.js全局引入的發(fā)方式,根據(jù)項(xiàng)目使用Echarts的程度可以選擇按需引入:
3、按需引入Echarts:
let Echarts = require('echarts/lib/echarts'); require('echarts/lib/chart/bar'); //所需圖表
簡(jiǎn)單使用:
首先應(yīng)該明確Echarts圖形必須滿足四項(xiàng)剛性條件才可以繪制:
準(zhǔn)備一個(gè)具有寬高的容器(container);每次繪制之前需要初始化(init);必須設(shè)置配置,否則無(wú)從繪制(option);改變數(shù)據(jù)時(shí)必須傳入改變的數(shù)據(jù),否則監(jiān)聽不到新數(shù)據(jù)(setOption);
四步缺一不可,可以簡(jiǎn)單理解為日常生活中娶媳婦:
找到適合結(jié)婚的女朋友(container);認(rèn)識(shí)一段時(shí)間之后確定關(guān)系(init);確定關(guān)系之后需要買買買,她才會(huì)跟你繼續(xù)交往(option);關(guān)系進(jìn)一步升溫之后就可以把他娶回家了(setOption);
使用:
<!-- 準(zhǔn)備具有寬高的容器 --> <div style="width: 100%; height: 100%" ref="chart"></div>
<script> let Echarts = require('echarts/lib/echarts'); //基礎(chǔ)實(shí)例 注意不要使用import require('echarts/lib/chart/bar'); //按需引入 bar = 柱狀圖 export default { data() { return { chart: null } }, //圖表實(shí)例 mounted() { this.init() }, methods: { init() { //2.初始化 this.chart = Echarts.init(this.$refs.chart); //3.配置數(shù)據(jù) let option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, //X軸 yAxis: { type: 'value' }, //Y軸 series: [{ data: [120, 200, 150, 80, 70, 110, 130], type: 'bar' }] //配置項(xiàng) }; // 4.傳入數(shù)據(jù) this.chart.setOption(option); } } }; </script>
自適應(yīng)窗口大?。?/strong>
為了兼容性,需要做到每個(gè)圖表根據(jù)屏幕變化而自適應(yīng)寬高
單個(gè) / 多個(gè)圖表均生效:
mounted() { window.addEventListener('resize', () => { this.chart.resize(); }); }
效果展示:
總結(jié)
到此這篇關(guān)于在Vue中使用Echarts可視化庫(kù)的文章就介紹到這了,更多相關(guān)Vue使用Echarts可視化庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解關(guān)于element el-button使用$attrs的一個(gè)注意要點(diǎn)
這篇文章主要介紹了詳解關(guān)于element el-button使用$attrs的一個(gè)注意要點(diǎn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2018-11-11Vue全局?jǐn)r截所有請(qǐng)求并在請(qǐng)求頭中添加token方式
這篇文章主要介紹了Vue全局?jǐn)r截所有請(qǐng)求并在請(qǐng)求頭中添加token方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08vue+element+oss實(shí)現(xiàn)前端分片上傳和斷點(diǎn)續(xù)傳
這篇文章主要介紹了vue+element+oss實(shí)現(xiàn)前端分片上傳和斷點(diǎn)續(xù)傳,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03詳解Vue中數(shù)組和對(duì)象更改后視圖不刷新的問題
這篇文章主要介紹了Vue中數(shù)組和對(duì)象更改后視圖不刷新的問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2018-09-09Vue3使用路由及配置vite.alias簡(jiǎn)化導(dǎo)入寫法的過程詳解
這篇文章主要介紹了Vue3使用路由及配置vite.alias簡(jiǎn)化導(dǎo)入寫法,本文通過實(shí)例代碼給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-11-11