vue-cli 中引入 ECharts

更新:2022-3-8

安裝好vue-cli后,cd 到項(xiàng)目目錄下,npm 安裝ECharts

npm install echarts --save

安裝好后就正式開(kāi)始:

方式一

在 src >> assets 下新建名為 js 的文件夾痴怨,并在該文件夾下創(chuàng)建 myCharts.js 文件
這個(gè)文件用來(lái)寫(xiě)所有的 ECharts 圖表方法都封裝在這里

import echarts from 'echarts'
let install = function(Vue) {
    Object.defineProperties(Vue.prototype, {
        $chart: {
            get() {
                return {
                    //一個(gè)簡(jiǎn)單的示例
                    first_bar: function (id) {
                        this.chart = echarts.init(document.getElementById(id));
                        this.chart.clear();
                        const optionData = {
                            title: {
                                text: 'ECharts 入門(mén)示例'
                            },
                            tooltip: {},
                            xAxis: {
                                data: ['襯衫', '羊毛衫', '雪紡衫', '褲子', '高跟鞋', '襪子']
                            },
                            yAxis: {},
                            series: [{
                                name: '銷(xiāo)量',
                                type: 'bar',
                                data: [5, 20, 36, 10, 10, 20]
                            }]
                        };
                        this.chart.setOption(optionData);
                    },
                }
            }
        }
    })
}
export default {
    install
}

在 main.js 文件內(nèi)引入剛剛所創(chuàng)建的文件

import myCharts from '@/assets/js/myCharts' //引入eCharts 文件
Vue.use(myCharts)

在需要引入ECharts圖表的插件頁(yè),調(diào)用已封裝的方法搅窿,在頁(yè)面上畫(huà)出圖表

<template>
    <div id="chart"></div>
</template>

<script>
export default {
    name: 'Home',
    mounted() {
        this.$chart.first_bar('chart'); //方法調(diào)用
    }
}
</script>

<style scoped>
    #chart {
        width: 300px;
        height: 300px;
    }
</style>

最后节值,在頁(yè)面上就可以看到畫(huà)好的圖表了

示例截圖.png

方式二(推薦)

不同于方式一,這種方式不需要新建單獨(dú)文件,也不需要在main.js中引入焰情,只需要在需要編輯圖表的組件中陌凳,如下:

import echarts from 'echarts' //引入echarts
export default {
    name: 'comRadar', 
    data(){
        return {
            myChart: {},
        }
    },
    methods:{ // 方法
        init() {
            /**
             * 注意:當(dāng)組件被多次調(diào)用,控制臺(tái)會(huì)報(bào)錯(cuò)内舟,
             * 原因:組件被多次渲染 document.getElementById 重復(fù)獲取dom
             * 思路:通過(guò)ref獲取當(dāng)前組件下指定的 dom 節(jié)點(diǎn)
             * 舉例:echarts.init(this.$refs.radarCase.querySelector('.radar_case))
             */
            this.myChart = echarts.init(document.getElementById("radar_case"));
            window.addEventListener('resize', this.resize)
        },
        sizeChange(){
            this.myChart.resize();
        }
    },
    mounted() {// 生命周期鉤子合敦,這里不能用 created
        this.init();
        let optionData = {
            // 圖表數(shù)據(jù)(略)
        };
        this.myChart.setOption(optionData);
    },
    beforeDestroy() {
        // 移除監(jiān)聽(tīng)
        window.removeEventListener('resize', this.resize);
    },
}

這樣就可以了,同時(shí)這種方式验游,圖表大小可以根據(jù)窗口改變大小充岛。

EChart 5.x 變化

EChart 更新到5后,使用上邊的引入方式會(huì)報(bào)錯(cuò)8酢4薰!!請(qǐng)改用下邊的方式引入_

import * as echarts from "echarts";

頁(yè)面數(shù)據(jù)改變地圖顯示移位

有時(shí)候經(jīng)常遇到垒在,地圖引入蒜魄,在第一頁(yè)的時(shí)候?qū)⒌貓D大小改變,當(dāng)?shù)貓D數(shù)據(jù)切換時(shí)场躯,新的地圖位置移位谈为,這是因?yàn)橹皇歉淖兞说貓D數(shù)據(jù),地圖并沒(méi)有重新生成踢关。

解決辦法:

//在setOption()方法中添加true伞鲫,表示重新繪制。
this.chart.setOption(this.setOption(),true) 

自定義地圖數(shù)據(jù)網(wǎng)址
圖表實(shí)例網(wǎng)址(官網(wǎng)提供耘成,2022.2.15 以暫停使用)
PPChart(復(fù)刻 Make A Pie)
ChartLib(復(fù)刻 Make A Pie)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末榔昔,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子瘪菌,更是在濱河造成了極大的恐慌撒会,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,348評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件师妙,死亡現(xiàn)場(chǎng)離奇詭異诵肛,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)默穴,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén)怔檩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人蓄诽,你說(shuō)我怎么就攤上這事薛训。” “怎么了仑氛?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,936評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵乙埃,是天一觀的道長(zhǎng)闸英。 經(jīng)常有香客問(wèn)我,道長(zhǎng)介袜,這世上最難降的妖魔是什么甫何? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,427評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮遇伞,結(jié)果婚禮上辙喂,老公的妹妹穿的比我還像新娘。我一直安慰自己鸠珠,他們只是感情好巍耗,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,467評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著跳芳,像睡著了一般芍锦。 火紅的嫁衣襯著肌膚如雪竹勉。 梳的紋絲不亂的頭發(fā)上飞盆,一...
    開(kāi)封第一講書(shū)人閱讀 49,785評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音次乓,去河邊找鬼吓歇。 笑死,一個(gè)胖子當(dāng)著我的面吹牛票腰,可吹牛的內(nèi)容都是我干的城看。 我是一名探鬼主播,決...
    沈念sama閱讀 38,931評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼杏慰,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼测柠!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起缘滥,我...
    開(kāi)封第一講書(shū)人閱讀 37,696評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤扼菠,失蹤者是張志新(化名)和其女友劉穎框沟,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,141評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡柑船,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,483評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蜀肘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蔓钟。...
    茶點(diǎn)故事閱讀 38,625評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖搂捧,靈堂內(nèi)的尸體忽然破棺而出驮俗,到底是詐尸還是另有隱情,我是刑警寧澤允跑,帶...
    沈念sama閱讀 34,291評(píng)論 4 329
  • 正文 年R本政府宣布王凑,位于F島的核電站提佣,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏荤崇。R本人自食惡果不足惜拌屏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,892評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望术荤。 院中可真熱鬧倚喂,春花似錦、人聲如沸瓣戚。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)子库。三九已至舱权,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間仑嗅,已是汗流浹背宴倍。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留仓技,地道東北人鸵贬。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像脖捻,于是被迫代替她去往敵國(guó)和親阔逼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,492評(píng)論 2 348