Vue中引入echarts的正确引法

  • 在做Vue的电商管理系统时遇到了一个一直给我提示init未定义的警告
    [Vue warn]: Error in mounted hook (Promise/async): “TypeError: Cannot read property ‘init’ of undefined”
    看了其他博客的解决办法,是要利用Vue中的ref和$refs 来代替document.getElementById()获取该图形容器对象。
    但然后我发现是引用的语句问题,只要将import echarts from 'echarts’修改成import * as echarts from 'echarts’就不报错了
    注意:import * as xxx from ‘xxx’ 会将 “xxx” 中所有 export 导出的内容组合成一个对象返回(或import * as obj from ‘xx’ 这种写法是把所有的输出包裹到obj对象里);
<!--  -->
<template>
  <div>
    <!--面包屑导航区-->
    <el-breadcrumb separator="/">
      <el-breadcrumb-item :to="{ path: '/home' }">首页</el-breadcrumb-item>
      <el-breadcrumb-item>数据统计</el-breadcrumb-item>
      <el-breadcrumb-item>数据报表</el-breadcrumb-item>
    </el-breadcrumb>
    <!--卡片视图区域-->
    <el-card>
      <!-- 2、为ECharts准备一个具备大小(宽高)的Dom -->
      <div id="main" style="width: 750px; height: 400px"></div>
    </el-card>
  </div>
</template>

<script>
// 1、导入echarts
import echarts from 'echarts'
import _ from 'lodash'
export default {
  data() {
    return {
      // 需要合并的数据
      options: {
        title: {
          text: '用户来源',
        },
        tooltip: {
          trigger: 'axis',
          axisPointer: {
            type: 'cross',
            label: {
              backgroundColor: '#E9EEF3',
            },
          },
        },
        grid: {
          left: '3%',
          right: '4%',
          bottom: '3%',
          containLabel: true,
        },
        xAxis: [
          {
            boundaryGap: false,
          },
        ],
        yAxis: [
          {
            type: 'value',
          },
        ],
      },
    }
  },

  created() {},
  // 此时页面上的元素已经被渲染完毕了
  async mounted() {
    // 3、基于准备好的dom,初始化echarts实例
    var myChart = echarts.init(document.getElementById('main'))

    const { data: res } = await this.$http.get('reports/type/1')
    if (res.meta.status !== 200)
      return this.$message.error('获取时间统计的折线图失败!')
    // 4、准备数据和配置项
    const result = _.merge(res.data, this.options)

    // 5、使用刚指定的配置项和数据显示图表,展示数据
    myChart.setOption(result)
  },
  methods: {},
}
</script>
<style lang='less' scoped>
</style>

效果图:
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值