uniapp微信小程序中使用echarts

1、下載所需要的庫(kù)
終端輸入 npm install echarts mpvue-echarts --save
將node_modules中的mpvue-echarts文件夾放入components目錄下,只保留其中的src文件夾


image.png

2、然后在https://echarts.apache.org/zh/builder.html定制echarts的js文件,然后下載诬辈,放到common目錄下

image.png

3、以折線圖為例

<template>
    <view>
        <view class="wrap">
            <mpvue-echarts :onInit="initChart" />
        </view>
        <view @click="drawAgain">重新繪制</view>
        <view @click="drawAgain1">重新繪制2</view>
    </view>
</template>

<script>
import * as echarts from '@/common/echarts.min'; /*chart.min.js為在線定制*/
import mpvueEcharts from '@/components/mpvue-echarts/src/echarts.vue';
let chart = null;
export default {
    data() {
        return {
            option: {
                backgroundColor: '#fff',
                color: ['#ec562e'],
                 tooltip: {
                    trigger: 'axis'
                  },
                xAxis: {
                    type: 'category',
                    data: ['周一', '周二', '周三']
                },
                yAxis: {
                    x: 'center',
                    type: 'value',
                    splitLine: {
                        lineStyle: {
                            color:'#999999',
                            type: 'dashed'
                        }
                    }
                },
                series: [
                    {
                        name: '價(jià)格',
                        type: 'line',
                        smooth: true,
                        data: [70,50,60],
                    }
                ]
            }
        };
    },
    methods: {
        initChart(canvas, width, height) {
            chart = echarts.init(canvas, null, {
                width: width,
                height: height
            });
            canvas.setChart(chart);
            return chart;
        },
        drawAgain() {
            this.$set(this.option.xAxis, 'data', ['周一', '周二', '周三']);
            this.$set(this.option.series[0], 'data', [78, 40, 33]);
            chart.setOption(this.option);
        },
        drawAgain1() {
            this.$set(this.option.xAxis, 'data', ['周一', '周二', '周三', '周4']);
            this.$set(this.option.series[0], 'data', [78, 40, 33, 50]);
            chart.setOption(this.option);
        }
    },
    components: {
        mpvueEcharts
    }
};
</script>

<style>
.wrap {
    width: 100%;
    height: 300px;
}
</style>

運(yùn)行時(shí)提示this.echarts.setCanvasCreator is not a function的錯(cuò)誤
解決方法:
1、找到components--》mpvue-echarts--》src--》echarts.vue
導(dǎo)入import * as echarts from '@/common/echarts.min'; /echarts.min.js為在線定制/
2磕洪、注釋props中的echarts,如下

export default {
  props: {
    // echarts: {
    //   required: true,
    //   type: Object,
    //   default() {
    //     return null;
    //   },
    // },
    onInit: {
      type: Function,
      default: null,
    },
    canvasId: {
      type: String,
      default: 'ec-canvas',
    },
    lazyLoad: {
      type: Boolean,
      default: false,
    },
    disableTouch: {
      type: Boolean,
      default: false,
    },
    throttleTouch: {
      type: Boolean,
      default: false,
    },
  },

3诫龙、在 onReady方法中添加 this.echarts = echarts

 onReady() {
      this.echarts = echarts  //新增
    if (!this.echarts) {
      console.warn('組件需綁定 echarts 變量析显,例:<ec-canvas id="mychart-dom-bar" '
        + 'canvas-id="mychart-bar" :echarts="echarts"></ec-canvas>');
      return;
    }

    if (!this.lazyLoad) this.init();
  },

4、init方法中修改以下3處
const canvasId = this.canvasId; //------修改------
this.ctx = wx.createCanvasContext(canvasId,this);//------修改------
const query = wx.createSelectorQuery().in(this); //------修改------

init(callback) {
      const version = wx.version.version.split('.').map(n => parseInt(n, 10));
      const isValid = version[0] > 1 || (version[0] === 1 && version[1] > 9)
        || (version[0] === 1 && version[1] === 9 && version[2] >= 91);
      if (!isValid) {
        console.error('微信基礎(chǔ)庫(kù)版本過(guò)低签赃,需大于等于 1.9.91谷异。'
          + '參見:https://github.com/ecomfe/echarts-for-weixin'
          + '#%E5%BE%AE%E4%BF%A1%E7%89%88%E6%9C%AC%E8%A6%81%E6%B1%82');
        return;
      }

      const canvasId = this.canvasId;  //------***修改***------
      this.ctx = wx.createCanvasContext(canvasId,this);//------***修改***------

      const canvas = new WxCanvas(this.ctx, canvasId);

      this.echarts.setCanvasCreator(() => canvas);

      const query = wx.createSelectorQuery().in(this);  //------***修改***------
      query.select(`#${canvasId}`).boundingClientRect((res) => {
        if (!res) {
          setTimeout(() => this.init(), 50);
          return;
        }

        const { width, height } = res;

        if (typeof callback === 'function') {
          this.chart = callback(canvas, width, height);
        } else if (typeof this.onInit === 'function') {
          this.chart = this.onInit(canvas, width, height);
        }

        if (!this.chart) {
          return;
        }

        const { handler } = this.chart.getZr();

        this.handler = handler;
        this.processGesture = handler.proxy.processGesture || (() => {});
      }).exec();
    },

參考文章:
uniapp在微信小程序中使用 ECharts
https://blog.csdn.net/wxh958548129/article/details/107520566
uni-app使用mpvue-echarts報(bào) 的解決辦法
https://ask.dcloud.net.cn/article/36652

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末分尸,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子歹嘹,更是在濱河造成了極大的恐慌箩绍,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,948評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件荞下,死亡現(xiàn)場(chǎng)離奇詭異伶选,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)尖昏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,371評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門仰税,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人抽诉,你說(shuō)我怎么就攤上這事陨簇。” “怎么了迹淌?”我有些...
    開封第一講書人閱讀 157,490評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵河绽,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我唉窃,道長(zhǎng)耙饰,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,521評(píng)論 1 284
  • 正文 為了忘掉前任纹份,我火速辦了婚禮苟跪,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蔓涧。我一直安慰自己件已,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,627評(píng)論 6 386
  • 文/花漫 我一把揭開白布元暴。 她就那樣靜靜地躺著篷扩,像睡著了一般。 火紅的嫁衣襯著肌膚如雪茉盏。 梳的紋絲不亂的頭發(fā)上鉴未,一...
    開封第一講書人閱讀 49,842評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音鸠姨,去河邊找鬼歼狼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛享怀,可吹牛的內(nèi)容都是我干的羽峰。 我是一名探鬼主播,決...
    沈念sama閱讀 38,997評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼梅屉!你這毒婦竟也來(lái)了值纱?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,741評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤坯汤,失蹤者是張志新(化名)和其女友劉穎虐唠,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體惰聂,經(jīng)...
    沈念sama閱讀 44,203評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡疆偿,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,534評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了搓幌。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片杆故。...
    茶點(diǎn)故事閱讀 38,673評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖溉愁,靈堂內(nèi)的尸體忽然破棺而出处铛,到底是詐尸還是另有隱情,我是刑警寧澤拐揭,帶...
    沈念sama閱讀 34,339評(píng)論 4 330
  • 正文 年R本政府宣布撤蟆,位于F島的核電站,受9級(jí)特大地震影響堂污,放射性物質(zhì)發(fā)生泄漏家肯。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,955評(píng)論 3 313
  • 文/蒙蒙 一盟猖、第九天 我趴在偏房一處隱蔽的房頂上張望讨衣。 院中可真熱鬧,春花似錦扒披、人聲如沸值依。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,770評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至颇蜡,卻和暖如春价说,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背风秤。 一陣腳步聲響...
    開封第一講書人閱讀 32,000評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工鳖目, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人缤弦。 一個(gè)月前我還...
    沈念sama閱讀 46,394評(píng)論 2 360
  • 正文 我出身青樓领迈,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子狸捅,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,562評(píng)論 2 349