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知识库 -> echarts的一次使用 -> 正文阅读

[JavaScript知识库]echarts的一次使用

先上效果在这里插入图片描述在这里插入图片描述

在这里插入图片描述

// 监测视口大小
    window.addEventListener('resize', () => {
      setTimeout(() => {
        this.myEchart && this.myEchart.resize()
      }, 200)
    })


<template>
  <div class="analysisChart">
    <div ref="myDiv" :style="{height}" class="com-rank" />
  </div>
</template>

<script>
import * as echarts from 'echarts'
import { mapGetters } from 'vuex'
import { getColor } from '@/views/dataCenter/api/configEchartsColor'
export default {
  name: 'analysisChart',
  props: {
    // 分析模块
    type: {
      type: String
    },
    // 图表数据
    chartData: {
      type: [Array, Object, String]
    },
    // 分析图表类型
    charType: {
      type: Number,
      default: 1
    },
    // id
    // id: {
    //   type: String,
    //   default: () => ''
    // },
    height: {
      type: String,
      default: () => '425px'
    },
    distributionType: {
      type: String,
      default: () => ''
    }
  },
  data() {
    return {
      myEchart: '',
      chooseColor: {}
    }
  },
  computed: {
    ...mapGetters([
      'sidebar'
    ]),
    // x轴数据
    xData() {
      let xAxes = []
      if (this.type === 'event') { //事件
        xAxes = this.chartData[0].eventAnalysisLineVOS.map(item => item.eventTime)
      } else if (this.type === 'retained') { //留存
        // eslint-disable-next-line no-unused-expressions
        xAxes = this.chartData?.endEventVos.map(item => item.eventTime)
      } else if (this.type === 'funnel') { //漏斗
        xAxes = this.chartData.map(item => item.eventTime)
      } else if (this.type === 'distribute') { //分布
        if (this.charType === 1) {
          xAxes = this.chartData.map(item => item.groupValue)
        } else if (this.charType === 2) {
          if (this.distributionType === 'dataKanban') {
            xAxes = this.chartData.map(item => item.groupValue)
          } else {
            xAxes = this.chartData[0].list.map(item => item.eventTime)
          }
        }
      } else if (this.type === 'dataKanban') {
        xAxes = this.chartData.map(item => item.eventTime)
      }
      return xAxes
    },
    // 文字提示数据
    legendData() {
      let legend = []
      if (this.type === 'event') {
        legend = this.chartData.map(item => {
          if (item.eventAnalysisLineVOS[0]) {
            return item.eventAnalysisLineVOS[0].name
          }
        })
      }
      return legend
    },
    // 折线数据 analysisChart
    seriesData() {
      let series = []
      // 根据模块不同生成不同echart的series数据
      if (this.type === 'event') {
        series = this.chartData.map(item => {
          let type = ''
          if (this.charType === 1 || this.charType === 2) {
            type = 'line'
          } else {
            type = 'bar'
          }
          return {
            name: item.eventAnalysisLineVOS[0]?.name,
            data: item.eventAnalysisLineVOS.map(item1 => item1.countNum),
            type,
            stack: this.charType === 2 ? 'Total' : '',
            areaStyle: this.charType === 2 ? {} : null,
            emphasis: this.charType === 2 ? { focus: 'series' } : ''
          }
        })
      } else if (this.type === 'retained') {
        series.push(
          {
            name: this.chartData?.eventTime,
            data: this.chartData?.endEventVos.map(item => item.count),
            type: 'line'
          }
        )
      } else if (this.type === 'funnel') {
        series.push(
          {
            name: '总转化率',
            data: this.chartData.map(item => item.rate),
            type: 'line'
          }
        )
      } else if (this.type === 'distribute') {
        if (this.charType === 1) {
          series.push({
            type: 'bar',
            data: this.chartData.map(item => item.countNum),
            name: '分布数'
          })
        } else if (this.charType === 2) {
          series = this.chartData.map(item => {
            return {
              stack: 'Total',
              areaStyle: {},
              emphasis: {
                focus: 'series'
              },
              type: 'line',
              name: item.groupValue,
              data: item.list.map(item1 => item1.countNum)
            }
          })
        }
      } else if (this.type === 'dataKanban') {
        if (this.charType === 3) {
          series.push({
            type: 'bar',
            data: this.chartData.map(item => item.countNum),
            name: '任意事件'
          })
        } else if (this.charType === 2) {
          series.push({
            stack: 'Total',
            areaStyle: {},
            emphasis: {
              focus: 'series'
            },
            type: 'line',
            name: '任意事件',
            data: this.chartData.map(item => item.countNum)
          })
        }
      }
      return series
    }
  },
  watch: {
    // 监测侧边连隐藏显示
    'sidebar.opened'() {
      setTimeout(() => {
        this.myEchart && this.myEchart.resize()
      }, 200)
    },
    chartData: {
      handler(newVal, oldVal) {
        if (newVal.length === 0) {
          return
        }
        this.createChart()
      },
      deep: true
    }
  },
  created() {
    this.chooseColor = getColor()
  },
  mounted() {
    // 监测视口大小
    window.addEventListener('resize', () => {
      setTimeout(() => {
        this.myEchart && this.myEchart.resize()
      }, 200)
    })
    this.createChart()
  },
  methods: {
    createChart() {
      this.myEchart = this.$echarts.init(this.$refs.myDiv)// 得到图表实例
      this.myEchart.setOption(
        {
          color: ['#2C51EF', '#12C5D2', '#FC7F2B', '#FECE2B', '#F54E5A', '#4CBD11', '#B365FF'],
          title: {
            text: ''
          },
          tooltip: {
            trigger: 'axis',
            position: function (point, params, dom, rect, size) {
              //  size为当前窗口大小
              if ((size.viewSize[0] / 2) >= point[0]) {
                //其中point为当前鼠标的位置
                return [point[0] + 50, '10%']
              } else {
                //其中point为当前鼠标的位置
                return [point[0] - 200, '10%']
              }
            }
          },
          legend: {
            data: this.legendData,
            bottom: '0',
            left: 'center',
            type: 'scroll',
            icon: 'circle',
            textStyle: {
              color: this.chooseColor.titleColor
            }
          },
          grid: {
            left: '2%',
            right: '25px',
            bottom: '9%',
            top: '2%',
            containLabel: true
          },
          // toolbox: {
          //   feature: {
          //     saveAsImage: {}
          //   }
          // },
          xAxis: {
            type: 'category',
            // boundaryGap: false,
            data: this.xData,
            axisLine: {
              lineStyle: {
                color: this.chooseColor.textColor
              }
            }
          },
          yAxis: {
            type: 'value',
            axisLine: {
              lineStyle: {
                color: this.chooseColor.textColor
              }
            }
          },
          series: JSON.parse(JSON.stringify(this.seriesData)).map(item => {
            if (this.type === 'dataKanban' || this.type === 'distribute') {
              if (item.type === 'bar') {
                return item
              } else {
                item.symbol = 'circle'//折线图点变实心
                item.symbolSize = '7'
                item.itemStyle = {//点和两边线有距离
                  borderColor: 'rgba(255, 255, 255, 1)',
                  borderWidth: 1
                }
              }
            } else {
              item.symbol = 'circle'//折线图点变实心
              item.symbolSize = '7'
              item.itemStyle = {//点和两边线有距离
                borderColor: 'rgba(255, 255, 255, 1)',
                borderWidth: 1
              }
            }
            return item
          })
        }, true)
      this.myEchart.off('click')
      this.myEchart.on('click', (params) => {
      })
    }
  }
}
</script>

<style lang="scss" scoped>
// .analysisChart {
//   .myDiv {
//     height: 425px;
//   }
// }
</style>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-08 22:20:01  更:2022-03-08 22:20:49 
 
开发: 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/10 10:39:07-

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