IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> echart legend和 tooltip自定义内容和形状;x轴y轴修改样式 -> 正文阅读

[JavaScript知识库]echart legend和 tooltip自定义内容和形状;x轴y轴修改样式

在这里插入图片描述


<div ref="pie" style="height:220px; width: 80%;"></div>


   getPie() {
        const pie = this.$refs.pie
        const pieChart = this.$echarts.init(pie, 'light')
        let seriesDataPie = [];
        var res = [
          { value: 1048, name: '父亲' },
          { value: 735, name: '母亲' },
          { value: 580, name: '哥哥' },
          { value: 484, name: '姐姐' },
          { value: 300, name: '妹妹' }
        ]
        // request.getData({ thisMonth: 1 }).then(({
        request.getData().then(({
          object
        }) => {
          console.log("33333", object)

          if (res.length > 0) {
            const total = 10
            const option = {
              title: {},
              tooltip: {
                trigger: 'item',
                formatter: "{b}:{c}"
              },
              legend: {
                top: 'center',
                orient: 'vertical',
                right: 'right',
                icon: "circle",   //  字段控制形状  类型包括 circle,rect,line,roundRect,triangle,diamond,pin,arrow,none

                formatter: function (name) {
                  var data = res;
                  var total = 0;
                  var target;
                  data.forEach((item, index) => {
                    total += data[index].value;
                    if (data[index].name == name) {
                      target = data[index].value;
                    }
                  })
                  return name + '  ' + target;
                  //return ((target / total) * 100).toFixed(2) + '%'
                },

              },
              series: [
                {
                  type: 'pie',
                  radius: ['50%', '70%'],
                  center: ["40%", "60%"],
                  label: {
                    show: false,
                    position: 'center'
                  },
                  emphasis: {
                    label: {
                      show: true,
                      fontSize: '20',
                      fontWeight: 'bold',
                      formatter: "{b}:{d}%" /*饼状图内显示百分比*/,
                    },
                  },

                  data: res
                }
              ]
            }

            pieChart.setOption(option)

            window.addEventListener('resize', function () {
              pieChart.resize()
            })
            this.$on('hook:destroyed', () => {
              window.removeEventListener('resize', () => {
                pieChart.resize()
              })
            })
          } else {
            this.msg = '暂无数据'
          }
        })
      },
   

在这里插入图片描述

          <div ref="barMonitor" style="height:240px;" :class="{'chartMsg':msg!=''}" v-html="msg">{{ msg }}</div>


   getBarMonitor() {
        const barMonitor = this.$refs.barMonitor
        const barMonitorChart = this.$echarts.init(barMonitor, 'light')
        barMonitor.removeAttribute("_echarts_instance_");
        request.getData().then(res => {
          const data = [{ time: 1, value: 120 }, { time: 2, value: 200 }, { time: 3, value: 150 },
          { time: 4, value: 80 }, { time: 5, value: 70 }, { time: 6, value: 110 },
          { time: 7, value: 130 }, { time: 8, value: 80 }, { time: 9, value: 90 },
          { time: 10, value: 100 }, { time: 11, value: 110 }, { time: 12, value: 120 }]
          var time = []
          var value = []
          data.forEach((item) => {
            time.push(item.time + "月")
            value.push(item.value)
          })
          const _this = this
          if (barMonitor && data.length > 0) {
            const option = {
              'grid': {
                'top': '40',
                'left': '0',
                'bottom': '5%',
                'right': '0',
                'containLabel': true
              },
              xAxis: {
                type: 'category',
                date: time,
                axisLine: {
                  show: false,
                },
                axisLabel: {//y轴文字的配置
                  textStyle: {
                    color: "#999",//Y轴内容文字颜色
                  },
                },
                axisLine: {//y轴线的配置
                  show: true,//是否展示
                  lineStyle: {
                    color: "#ECEDF0",//y轴线的颜色(若只设置了y轴线的颜色,未设置y轴文字的颜色,则y轴文字会默认跟设置的y轴线颜色一致)
                    width: 1,//y轴线的宽度
                    type: "solid"//y轴线为实线
                  },
                },
              },
              yAxis: {
                type: 'value',
                axisLine: {
                  show: false,
                },
                axisLabel: {//y轴文字的配置
                  textStyle: {
                    color: "#999",//Y轴内容文字颜色
                  },
                },
                axisLine: {//y轴线的配置
                  show: true,//是否展示
                  lineStyle: {
                    color: "#fff",//y轴线的颜色(若只设置了y轴线的颜色,未设置y轴文字的颜色,则y轴文字会默认跟设置的y轴线颜色一致)
                    width: 1,//y轴线的宽度
                    type: "solid"//y轴线为实线
                  },
                },
                splitLine: {//分割线配置
                  show: true,
                  lineStyle: {
                    color: "#f5f5f5",
                  },
                },
              },
              series: [
                {
                  data: value,
                  type: 'bar',
                  barWidth: 15,
                  color: new this.$echarts.graphic.LinearGradient(0, 0, 0, 1,
                    [
                      { offset: 0, color: "#35c0fd" },
                      { offset: 1, color: "#2c77f3" }
                    ],
                    false
                  ) // 渐变
                }
              ]
            }

            barMonitorChart.setOption(option)
            window.addEventListener('resize', function () {
              barMonitorChart.resize()
            })
            this.$on('hook:destroyed', () => {
              window.removeEventListener('resize', () => {
                barMonitorChart.resize()
              })
            })
          } else {
            this.msg = '暂无数据'
          }
        }).catch()
      },
    
legend: {
  icon: "circle",   //  字段控制形状  类型包括 circle,rect,line,roundRect,triangle,diamond,pin,arrow,none
  itemWidth: 10,  // 设置宽度
  itemHeight: 10, // 设置高度
  itemGap: 40 // 设置间距
},
 icon 可自定义图片
  icon : 'image://../../images/hsyb/water.png'   /* image://  后跟图片路径*/
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-14 09:51:45  更:2022-05-14 09:53:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 5:53:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码