首发于 web前端
vue使用Echarts  vue使用Echarts滚动条

vue使用Echarts vue使用Echarts滚动条

最近公司一个项目需要绘制图标,数据很多都要放在一张图标上面,说起图标肯定先想到Echarts , 刚好Echarts也配置了滚动条.下面分享一下

github:

npm安装:

npm install echarts -S

main.js 配置:

Vue.prototype.$echarts = echarts
Vue.config.productionTip = false

项目中:引入:

 let echarts = require('echarts/lib/echarts')

这样全局引入 打包 项目会很大;

可以再demo里单独引入:需要哪个模块引入哪个模块

require('echarts/lib/chart/bar')
    require('echarts/lib/component/tooltip')
    require('echarts/lib/component/title')
    require('echarts/lib/component/dataZoom')
    require('echarts/lib/component/dataset')

Echarts:色彩包

 import macarons from 'echarts/theme/macarons'

项目中

script>
  let echarts = require('echarts/lib/echarts')
  export default {
    name: 'hello',
    data() {
      return {
        data: []
    mounted() {
      this.drawLine();
    methods: {
      drawLine() {
        // 基于准备好的dom,初始化echarts实例
        let myChart = this.$echarts.init(document.getElementById('myChart'))
        // 绘制图表
        myChart.setOption({
          tooltip: {
            trigger: 'axis',
            axisPointer: { // 坐标轴指示器,坐标轴触发有效
              type: 'shadow' // 默认为直线,可选为:'line' | 'shadow'
          legend: {
            data: ['直接访问', '邮件营销', '联盟广告', '视频广告', '搜索引擎', '百度', '谷歌', '必应', '其他']
          toolbox: {
            show: true,
            orient: 'vertical',
            x: 'right',
            y: 'center',
            feature: {
              mark: {
                show: true
              dataView: {
                show: true,
                readOnly: false
              magicType: {
                show: true,
                type: ['line', 'bar', 'stack', 'tiled']
              restore: {
                show: true
              saveAsImage: {
                show: true
          calculable: true,
          xAxis: [{
            type: 'category',
            data: ['周一', '周二', '周三', '周四', '周五', '周六', '周日']
          yAxis: [{
            type: 'value'
          series: this.data, // 这里就放后台传过来的数据
          dataZoom: [{ // 这是滚动条插件  可以是Y轴 也可以是X轴
              type: 'inside',
              start: 0,
              end: 20
              start: 0,
              end: 20, //位置     下面这个是  自定义图标  格式可以是base64  url  inco 格式
              handleIcon: 'd="M625.353 69.801L844.722 343.814c0 0 11.085 102.239-87.737 59.17-57.017-25.586-77.367-79.29799999-77.367-79.298l-2.043 417.39c0 0-58.947 87.901-110.234 0l-0.934-264.25399999c0 0-63.75 86.74199999-138.747-6.064 0 0-56.248 94.518-135.27-4.57700001 0 0-56.03 109.298-112.278-9.485l0-331.75c0 0 3.25599999-25.862 48.862-55.145L625.353 69.801 625.353 69.801zM625.353 69.801"',
              handleSize: '80%', // 图标大小 
              handleStyle: { // 图标样式
                color: '#fff',
                shadowBlur: 3,
                shadowOffsetX: 4,
                shadowOffsetY: 2,
                transform: "rolate(90deg)" // 图标旋转
    created() {
      //  在created 里面 直接调用   this.drawLine();    回报这个错误   因为这里时候echarts还没有加载出来   created hook: "TypeError: Cannot read property 'getAttribute' of null"
      /*   axios.post('*********', ).then(res => { */
          var arr = []  // 在这里把数据过滤成Ehcarts 需要的格式 
          for (var i = 0; i < 10; i++) {
            var json = {
              name: '视频广告' + i,
              type: 'bar',
              stack: '广告',
              data: [150 + i, 2 - i, 20 * i, 154 - 100, 19 - 8, 30, 40]
            arr.push(json)
          this.data = arr
          // 主要 echarts不能v-if 也会报错