Vue项目中使用Echarts 和Echarts中水球liquidFill的中文API

  • Post author:
  • Post category:vue


一 安装Echarts

   npm install echarts echarts-liquidFill --save 

二 引入Echarts 在入口文件index.js中 如下所示 仅供参考

import Vue from 'vue'
import vueRouter from 'vue-router'
import Echarts from 'echarts'//引入echarts
import {router} from './router'
import App from './App.vue'
Vue.config.productionTip= false;
Vue.use(vueRouter);
Vue.prototype.$echarts = Echarts;//把echarts绑定在vue的原型上 这样在组件里面就可以通过this.$echarts来访问了
const routers = new vueRouter({
    mode:"hash",
    routes:router
})
new Vue({
    el: '#app',
    router: routers,
    components:{App},
    template: '<App/>'
})

三 在组建中使用水球liquidFill

<script>
   import echartsLiquidfill from 'echarts-liquidfill'//在这里引入
   export default {
       name:'Home',
    data() {
        return {
            counter: 1
        }
    },
    mounted() {//在这个生命周期中初始化
       this.liquidFill(); 
    },
    methods: {
       liquidFill (){//方法
           var liquid = this.$echarts.init(document.getElementById('liquidFill'));
           liquid.setOption({
               title: {//标题
                  text:'水球图',
                  textStyle: {//标题的样式
                      color:'#f60',//字体颜色
                      fontFamily: 'Microsoft YaHei',//字体
                      align: 'center',//文字的水平方式
                      verticalAlign: 'middle'//文字的垂直方式
                  },
                  left: 'center',//定位
                  backgroundColor: '#03dbdb'//文字区域的背景颜色
                },
                series: [{
                    type: 'liquidFill',//类型
                    data: [0.7, 0.5, 0.4,],//数据是个数组 数组的每一项的值是0-1
                    outline: {
                        //show: true , //是否显示轮廓 布尔值
                        borderDistance: 0, //外部轮廓与图表的距离 数字
                        itemStyle:{
                            //borderColor:'rgba(255,0,0,0.09)', //边框的颜色
                            borderWidth: 0,  //边框的宽度
                            //shadowBlur: 5 , //外部轮廓的阴影范围 一旦设置了内外都有阴影
                            //shadowColor: '#000' //外部轮廓的阴影颜色 
                        }
                    },
                    backgroundStyle: {
                        color:'rgba(255,0,0,0.1)',//图表的背景颜色
                        //borderWidth: '10',//图表的边框宽度
                        //borderColor: '#000',//图表的边框颜色
                        itemStyle: {
                            shadowBlur:100,//设置无用
                            shadowColor: '#f60',//设置无用
                            opacity: 1 //设置无用
                        }    
                    },
                    itemStyle: {
                        opacity:0.5,//波浪的透明度
                        shadowBlur: 10,//波浪的阴影范围
                        shadowColor:'#f60'//阴影颜色
                    },
                    emphasis:{
                        itemStyle: {
                            opacity :1 //鼠标经过波浪颜色的透明度
                        }
                    },
                    color: ['rgba(255,0,0,0.3)','rgba(255,0,0,0.3)','rgba(255,0,0,0.3)',],//水波的颜色 对应的是data里面值
                    shape: 'circle',//水填充图的形状 circle默认圆形  rect圆角矩形  triangle三角形  diamond菱形  pin水滴状 arrow箭头状  还可以是svg的path
                    center: ['50%','50%'],//图表相对于盒子的位置 第一个是水平的位置 第二个是垂直的值 默认是[50%,50%]是在水平和垂直方向居中 可以设置百分比 也可以设置具体值
                    radius: '80%', //图表的大小 值是圆的直径 可以是百分比 也可以是具体值 100%则占满整个盒子 默认是40%; 百分比下是根据宽高最小的一个为参照依据
                    amplitude:3,   //振幅 是波浪的震荡幅度 可以取具体的值 也可以是百分比 百分比下是按图标的直径来算
                    waveLength:'50%',//波的长度 可以是百分比也可以是具体的像素值  百分比下是相对于直径的 取得越大波浪的起伏越小
                    phase:0 ,//波的相位弧度 默认情况下是自动
                    period: (value,index)=>{//控制波的移动速度 可以是函数 也可以是数字 两个参数  value 是data数据里面的值 index 是data值的索引

                        return index*2000;
                    },
                    direction: 'left',//波移动的速度 两个参数  left 从右往左 right 从左往右
                    waveAnimation: true, //控制波动画的开关  值是布尔值 false 是关闭动画 true 是开启动画 也是默认值
                    animationEasing: 'linear',//初始动画
                    animationEasingUpdate: 'quarticInOut',//数据更新的动画效果
                    animationDuration: 3000, //初始动画的时长,支持回调函数,可以通过每个数据返回不同的 delay 时间实现更绚丽的初始动画效果
                    animationDurationUpdate : 300 //数据更新动画的时长

                }],
                //backgroundColor: 'rgba(255,0,0,0.1)'容器背景颜色
           })
       }
    }
   }
<script>



版权声明:本文为MrzhangxianshengJS原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。