返回顶部
首页 > 资讯 > 精选 >vue项目中如何封装echarts
  • 729
分享到

vue项目中如何封装echarts

2023-06-29 13:06:51 729人浏览 薄情痞子
摘要

本文小编为大家详细介绍“Vue项目中如何封装echarts”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue项目中如何封装echarts”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。场景Echarts使用时,

本文小编为大家详细介绍“Vue项目中如何封装echarts”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue项目中如何封装echarts”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

场景

  • Echarts使用时,都需要写一堆的option,如果每个图表都要写一个,一个文件里面的代码量是很大的

  • 不方便复用

需求

  • 方便复用

  • 展示类的图表,数据与业务、样式分离,只传数据就行

  • 项目里需要用到的图表会有多个,实现少代码自动化导入,不需要一个个import

  • 本人图表用在大屏数据可视化的情况比较多,采用的是等比缩放的方式,所以图表也能根据界面缩放自动缩放,不需要手动调用

  • 图表可配置

代码总览

涉及的文件如下(具体参考代码):

|-- src    |-- components        |-- chart            |-- index.vue    // 图表单文件组件,供界面调用            |-- index.js    // 实现自动化导入options里的图表option            |-- options    // 存放各种图表的option                |-- bar    // 随便一例子                    |-- index.js    |-- views        |-- chartTest    // 实例所在            |-- index.vue            |-- index.sCSS            |-- index.js|-- main.js    // 全局引入echarts图表

实现

components--chart--index.vue

这里定义了一个名为ChartView 的组件,开放了4个可配置的属性:宽度width,高度height, 是否自动调整大小autoResize(默认是), 图表的配置chartOption。

这里默认用canvas 渲染图表了,也可以用SVG的,自选吧

具体代码如下

<template>  <div class="chart">    <div ref="chart" : />  </div></template><script>// 引入 echarts 核心模块,核心模块提供了 echarts 使用必须要的接口。import * as echarts from 'echarts/core'// 引入柱状图图表,图表后缀都为 Chartimport {  BarChart} from 'echarts/charts'// 引入提示框,标题,直角坐标系组件,组件后缀都为 Componentimport {  TitleComponent,  TooltipComponent,  GridComponent} from 'echarts/components'// 引入 Canvas 渲染器,注意引入 CanvasRenderer 或者 SVGRenderer 是必须的一步import {  CanvasRenderer} from 'echarts/renderers'// 注册必须的组件echarts.use(  [TitleComponent, TooltipComponent, GridComponent, BarChart, CanvasRenderer])export default {  name: 'ChartView',  props: {    width: {      type: String,      default: '100%'    },    height: {      type: String,      default: '350px'    },    autoResize: {      type: Boolean,      default: true    },    chartOption: {      type: Object,      required: true    },    type: {      type: String,      default: 'canvas'    }  },  data() {    return {      chart: null    }  },  watch: {    chartOption: {      deep: true,      handler(newVal) {        this.setOptions(newVal)      }    }  },  mounted() {    this.initChart()    if (this.autoResize) {      window.addEventListener('resize', this.resizeHandler)    }  },  beforeDestroy() {    if (!this.chart) {      return    }    if (this.autoResize) {      window.removeEventListener('resize', this.resizeHandler)    }    this.chart.dispose()    this.chart = null  },  methods: {    resizeHandler() {      this.chart.resize()    },    initChart() {      this.chart = echarts.init(this.$refs.chart, '', {        renderer: this.type      })      this.chart.setOption(this.chartOption)      this.chart.on('click', this.handleClick)    },    handleClick(params) {      this.$emit('click', params)    },    setOptions(option) {      this.clearChart()      this.resizeHandler()      if (this.chart) {        this.chart.setOption(option)      }    },    refresh() {      this.setOptions(this.chartOption)    },    clearChart() {      this.chart && this.chart.clear()    }  }}</script>

components--chart--index.js

这里主要利用require.context,把options里面定义的图表遍历导入,这样就不需要在代码里一个个import了,特别是图表多的时候。

const modulesFiles = require.context('./options', true, /index.js$/)let modules = {}modulesFiles.keys().forEach(item => {  modules = Object.assign({}, modules, modulesFiles(item).default)})export default modules

components--chart--options

这里展示下如何封装自己想要的图表

在Echarts官方示例上随便选了个示例

vue项目中如何封装echarts

在options下新建一个bar目录,bar目录下新建一个index.js文件。(个人习惯而已,喜欢每个图表都独立文件夹存放。不喜欢这种方式的,可以不放目录,直接js文件,但是components--chart--index.js要对应修改下)

直接复制示例的option代码

index.js具体代码如下

const testBar = (data) => {  const defaultConfig = {    xAxis: {      type: 'cateGory',      data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']    },    yAxis: {      type: 'value'    },    series: [{      data: [120, 200, 150, 80, 70, 110, 130],      type: 'bar'    }]  }  const opt = Object.assign({}, defaultConfig)  return opt}export default {  testBar}

testBar方法是可以传参的,具体使用的时候,图表所需要配置的属性,如:data数据、图表颜色......等都可以作为参数传。

main.js

这里全局引入下封装的Echarts组件,方便界面调用。(至于单个引用的方式,就不必多说了)

具体代码如下:

import eChartFn from '@/components/chart/index.js'import ChartPanel from '@/components/chart/index.vue'Vue.component(ChartPanel.name, ChartPanel)Vue.prototype.$eChartFn = eChartFn

chartTest

这里展示下如何调用封装的bar图表,主要代码如下

index.vue

<chart-view class="chart-content" :chart-option="chartOpt" :auto-resize="true" height="100%" />

index.js

export default {  name: 'chartTestView',  data() {    return {      chartOpt: {}    }  },  mounted() {},  created() {    this.chartOpt = this.$eChartFn.testBar()  },  methods: {  },  watch: {}}

效果如下

vue项目中如何封装echarts

可以尝试拖动浏览器的大小,可以看到,图表也是随着浏览器的拖动自动缩放的。

代码

按代码总览的目录去代码里找着看就行了。

总结

Echarts用到的各种图表,基本上都可以在Echarts官方示例和Echarts可视化作品分享(已停服)上找到。

以上,封装了chart组件,按照上述方式,把图表的option配置和相关处理都放options文件夹下面,调用图表时传对应的option,也就几行代码的事情,算是比较方便了。

chart组件很方便复用的,直接就可以使用了。

补充

评论里说想动态修改option里面的属性,稍微做了个例子,动态修改pie图表的data和color属性,这个是直接生产就可以使用的例子了,直接参考代码就行了,不详细说了。想修改什么属性,直接传参就行。传具体参数可以,想修改的属性多了就把参数封装成一个JSON传也可以。懂得在封装的option里面灵活使用就行。

以下是新增的参考代码

|-- src    |-- components        |-- chart            |-- options    // 存放各种图表的option                |-- pie    // pie例子                    |-- index.js    |-- views        |-- chartTest    // 实例所在            |-- index.vue            |-- index.scss            |-- index.js

代码使用都是直接一行调用的

this.chartOpt2 = this.$eChartFn.getPieChart([100, 23, 43, 65], ['#36CBCB', '#FAD337', '#F2637B', '#975FE4'])

效果如下:

vue项目中如何封装echarts

补充2:图表高亮轮询,dispatchAction使用

效果图

vue项目中如何封装echarts

使用方法

加上:play-highlight="true"属性就行

&lt;chart-view class="chart-content" :chart-option="chartOpt2" :auto-resize="true" :play-highlight="true" height="100%" /&gt;

主要实现的代码在如下文件的playHighlightAction方法里面,参考的echarts 饼图调用高亮示例 dispatchAction(见文末)实现的。只是简单的高亮轮询,具体各种实现就自己看文档调样式了。

|-- src    |-- components        |-- chart            |-- index.js    // 实现自动化导入options里的图表option

附:echarts 饼图调用高亮示例 dispatchAction

 <!-- 为ECharts准备一个具备大小(宽高)的Dom -->    <div id="main" ></div>    <script type="text/javascript">        var myChart = echarts.init(document.getElementById('main'));        var app = {};        option = {            title:{                text:'饼图程序调用高亮示例',                left:'center'            },            tooltip:{                trigger:'item',                fORMatter:'{a}{b}:{c}{d}%'            },            legend:{                orient:'vertical', //图例列表的布局朝向。'horizontal''vertical'                left:'left',                data:['直接访问','邮件营销','联盟广告','视频广告','搜素引擎']            },            series:[                {                    name:'访问来源',                    type:'pie',                    radius:'55%',                    center:['50%','60%'],                    data:[                        {value:335,name:'直接访问'},                        {value:310,name:'邮件营销'},                        {value:234,name:'联盟广告'},                        {value:135,name:'视频广告'},                        {value:1548,name:'搜索引擎'},                    ],                    emphasis:{                        itemStyle:{                            shadowBlur:10,                            shadowOffsetX:0,                            shadowColor:'rgba(0,0,0,0.5)'                        }                    }                }            ]        };                app.currentIndex = -1;        setInterval(() => {            var dataLen = option.series[0].data.length;            //取消之前高亮的图形            myChart.dispatchAction({                type:'downplay',                seriesIndex:0,                dataIndex:app.currentIndex            });            app.currentIndex = (app.currentIndex + 1) % dataLen;            //高亮当前图形            myChart.dispatchAction({                type:'highlight',                seriesIndex:0,                dataIndex:app.currentIndex            });            //显示tooltip            myChart.dispatchAction({                type:'showTip',                seriesIndex:0,                dataIndex:app.currentIndex            })        }, 1000);        option && myChart.setOption(option);    </script>

vue项目中如何封装echarts

读到这里,这篇“vue项目中如何封装echarts”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

--结束END--

本文标题: vue项目中如何封装echarts

本文链接: https://lsjlt.com/news/325179.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • vue项目中如何封装echarts
    本文小编为大家详细介绍“vue项目中如何封装echarts”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue项目中如何封装echarts”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。场景Echarts使用时,...
    99+
    2023-06-29
  • vue项目如何雅的封装echarts
    这篇文章主要介绍“vue项目如何雅的封装echarts”,在日常操作中,相信很多人在vue项目如何雅的封装echarts问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue项目如何雅的封装echarts”的疑...
    99+
    2023-06-29
  • vue2项目中如何封装echarts地图
    这篇文章主要介绍了vue2项目中如何封装echarts地图的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue2项目中如何封装echarts地图文章都会有所收获,下面我们一起来看看吧。效果图先上个效果图吧,说明...
    99+
    2023-06-29
  • Vue项目中如何封装axios
    本文小编为大家详细介绍“Vue项目中如何封装axios”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue项目中如何封装axios”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、axios是什么axios 是...
    99+
    2023-06-30
  • vue项目中封装echarts的优雅方式分享
    目录场景需求代码总览实现components--chart--index.vuecomponents--chart--index.jscomponents--chart--optio...
    99+
    2024-04-02
  • vue2项目如何优雅封装echarts地图
    这篇文章主要介绍“vue2项目如何优雅封装echarts地图”,在日常操作中,相信很多人在vue2项目如何优雅封装echarts地图问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue2项目如何优雅封装ech...
    99+
    2023-06-29
  • vue中如何封装echarts公共组件
    这篇文章主要讲解了“vue中如何封装echarts公共组件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue中如何封装echarts公共组件”吧!定义图表公共样式是为了统一同一网站各页面图...
    99+
    2023-06-30
  • Vue项目中引入ECharts
    目录1.安装2.引入3.使用4.按需引入 ECharts 图表和组件 1.安装 使用如下命令通过 npm 安装 ECharts npm install echarts --sav...
    99+
    2024-04-02
  • 如何在vue项目中使用封装后的axios
    这篇文章给大家介绍如何在vue项目中使用封装后的axios,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。为什么要使用VueVue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以创建可维护性和可测试...
    99+
    2023-06-06
  • vue之项目中如何封装loading加载效果
    目录vue封装loading加载效果Loading.vueloading.jsmain.js中导入并使用项目中使用Loading加载总结vue封装loading加载效果 使用两个文件...
    99+
    2022-12-08
    vue loading加载效果 vue封装 封装loading加载效果
  • vue项目中axios的封装请求
    目录一、简介二、封装后1.封装步骤2.封装目标3. 使用新的 axios 封装API4.使用封装后的axios一、简介 axios 是一个轻量的HTTP客户端,它基于 XMLHttp...
    99+
    2024-04-02
  • Vue项目中封装axios的方法
    目录一、axios是什么特性基本使用二、为什么要封装三、如何封装设置接口请求前缀设置请求头与超时时间封装请求方法请求拦截器响应拦截器小结参考文献一、axios是什么 axios 是...
    99+
    2024-04-02
  • vue2项目中封装echarts地图的优雅方法
    目录前言能学到的知识效果图注意1、vue中echarts 5.x以下版本和5.x以上版本引入的区别2、记得在vue.config.js中开启运行时编译功能实现数据准备echarts地...
    99+
    2024-04-02
  • Axios在vue项目中的封装步骤
    目录1. 什么是Axios?2. 回顾Ajax3. 回顾Promise4. Vue封装Axios1. 什么是Axios? Axios 是一个基于 promise 的网络请求库,可以用...
    99+
    2024-04-02
  • Vue项目中如何封装axios(统一管理http请求)
    1、需求说明 在使用Vue.js框架开发前端项目时,会经常发送ajax请求服务端接口,在开发过程中,需要对axios进一步封装,方便在项目中的使用。 2、Vue项目结构 在本地创...
    99+
    2024-04-02
  • Vue项目中怎么引入ECharts
    本篇内容主要讲解“Vue项目中怎么引入ECharts”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue项目中怎么引入ECharts”吧!1.安装使用如下命令通过 npm 安装 EChartsn...
    99+
    2023-07-05
  • vue项目如何引入element ui、iview和echarts
    目录vue引入element ui、iview和echarts1.vue项目引入elementui2.vue项目中引入iview3.vue项目中引入echarts4.main.js文...
    99+
    2024-04-02
  • vue中封装echarts公共组件过程
    目录1、安装echarts2、在mian.js中全局引入3、下面开始封装图表4、接下来只需要在需要显示图表的地方引入Echart.vue定义图表公共样式是为了统一同一网站各页面图表的...
    99+
    2024-04-02
  • 如何在java项目组中进行封装
    今天就跟大家聊聊有关如何在java项目组中进行封装,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。java 中的封装介绍及使用方法在面向对象程式设计方法中,封装(英语:Encapsul...
    99+
    2023-05-31
    java ava
  • VUE项目中封装Echart折线图的方法
    本文实例为大家分享了VUE项目中封装Echart折线图的具体代码,供大家参考,具体内容如下 封装Echart折线图,可显示多条折线 1. 首先在项目中全局引入Echarts,main...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作