echarts点击柱状图带参数跳转到指定页面(路由)

echarts点击柱状图带参数跳转到指定页面(路由)

项目开发者常用echarts来实现数据可视化功能。上次遇到了一个问题,就是通过后台返回的数据渲染echarts数据完成后需要点击柱形图图标的时候跳转制定的新的页面展示(当然新的页面内容,后台通过柱形图的参数来给我们返回过来的)

1,引入echarts

2,准备渲染echarts的区域div 

3,通过后台数据渲染数据

init2(arr) {
        let labelData = []
        let valueData = []
        let num = 0
        arr.forEach(item => {
          labelData.push(item.label)
          valueData.push(item.value)
          num += parseInt(item.value)
        })
        labelData.push('')
        valueData.push(0)
        // 基于准备好的dom,初始化echarts实例
        this.myChart1 = echarts.init(document.getElementById('echart1'));
        let option1 = {
          title: {
            text: '数据不合格数量: ' + num,
            left: 'center'
          },
          xAxis: {
            type: '',
            data: labelData,
            axisLabel: {
              interval: 0,
              rotate: -15
            },
            name: "(公司)"
          },
          yAxis: {
            type: 'value',
            name: "(数量)",
          },
          series: [
            {
              name: '销量',
              data: valueData,
              type: 'bar',
              itemStyle: {
                normal: {
                  barBorderRadius: [4, 4, 0, 0],
                  color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
                    { offset: 0, color: '#1FB9CE' },
                    { offset: 1, color: '#0846A3' },
                  ])
                }
              },
              label: {
                show: true,
                position: 'top'
              },
            }
          ]
        }
        // 绘制图表
        this.myChart1.setOption(option1)
// ------echarts点击事件获取对应的index和公司名称-------------
        // echarts点击事件获取对应的index和公司名称---跳转对应的数据核查页面ok
        this.myChart1.getZr().on('click', params => { // 柱形图点击事件
              var pointInPixel = [params.offsetX, params.offsetY]
              // 判断给定的点是否在指定的坐标系
              if (this.myChart1.containPixel('grid', pointInPixel)) {
                const xIndex = this.myChart1.convertFromPixel({ seriesIndex: 0 }, [params.offsetX, params.offsetY])[0]
                const option = this.myChart1.getOption()
                const xAxis = option.xAxis
                const name = xAxis[0].data[xIndex]
                console.log(xIndex)
                console.log(name)
                // console.log('--------打印index和公司名称-----------------')
                if (name !== undefined || name === '') { // 非空校验,防止没数据点击空白图表跳转
                  // 路由跳转传参
                  this.$router.push({
                    path: 'dataVerification',
                    query: {
                      echartsIndex: xIndex, //index值
                      echartsName: name,   //公司名称
                    }
                  })
                  console.log(this.$route.query)
                }
              }
        })
// -------------------
        window.addEventListener("resize", () => {
          this.myChart1.resize();
        });
      },

 4,实现点击柱形图图标带参数跳转制定页面(核心代码)

    // echarts点击事件获取对应的index和公司名称---跳转对应的数据核查页面ok
        this.myChart1.getZr().on('click', params => { // 柱形图点击事件
              var pointInPixel = [params.offsetX, params.offsetY]
              // 判断给定的点是否在指定的坐标系
              if (this.myChart1.containPixel('grid', pointInPixel)) {
                const xIndex = this.myChart1.convertFromPixel({ seriesIndex: 0 }, [params.offsetX, params.offsetY])[0]
                const option = this.myChart1.getOption()
                const xAxis = option.xAxis
                const name = xAxis[0].data[xIndex]
                console.log(xIndex)
                console.log(name)
                // console.log('--------打印index和公司名称-----------------')
                if (name !== undefined || name === '') { // 非空校验,防止没数据点击空白图表跳转
                  // 路由跳转传参
                  this.$router.push({
                    path: 'dataVerification',
                    query: {
                      echartsIndex: xIndex, //index值
                      echartsName: name,   //公司名称
                    }
                  })
                  console.log(this.$route.query)
                }
              }
        })

5,跳转完成-再新的页面接受参数

 

posted @ 2023-01-10 12:06  Mahmud(مەھمۇد)  阅读(2387)  评论(0编辑  收藏  举报