zoukankan      html  css  js  c++  java
  • vue中echarts的tooltip轮播(echarts版本:4.1.0)

    现在在项目中需要实现echarts图表的tooltip的轮播

    GitHub地址(如果有用不要吝啬你的赞)

    echarts2.0的API中可以找到如下描述:

    这里我们知道,要实现轮播主要就是使用dispatchAction

    以下是实现代码:

    var count = 0;
    var timeTicket = null;
    timeTicket && clearInterval(timeTicket);
    timeTicket = setInterval(function () { //设置定时循环
      myChart.dispatchAction({
        type: "downplay", //serieIndex的索引值
        seriesIndex: 0 //serieIndex的索引值   可以触发多个
      });
      myChart.dispatchAction({
        type: "highlight",//取消高亮指定的数据图形
        seriesIndex: 0,
        dataIndex: count
      });
      myChart.dispatchAction({
        type: "showTip", //显示浮云框
        seriesIndex: 0,
        dataIndex: count
     });
     count++;
     if (count >= num) {
       count = 0
     }
    },
    3000);

    上述代码只能实现循环,但是鼠标的移入移出事件会受到影响

    还需添加鼠标的mouseover事件和mouseout事件:

      var count = 0;
      var timeTicket = null;
      timeTicket && clearInterval(timeTicket);
      timeTicket = setInterval(function () {
        myChart.dispatchAction({
          type: "downplay",
          seriesIndex: 0 //serieIndex的索引值   可以触发多个
        });
        myChart.dispatchAction({
          type: "highlight",
          seriesIndex: 0,
          dataIndex: count
        });
        myChart.dispatchAction({
          type: "showTip",
          seriesIndex: 0,
          dataIndex: count
        });
        count++;
        if (count >= num) {
          count = 0
        }
      }, time);
      myChart.on("mouseover", function (params) {
        clearInterval(timeTicket);
        myChart.dispatchAction({
          type: "downplay",
          seriesIndex: 0
        });
        myChart.dispatchAction({
          type: "highlight",
          seriesIndex: 0,
          dataIndex: params.dataIndex
        });
        myChart.dispatchAction({
          type: "showTip",
          seriesIndex: 0,
          dataIndex: params.dataIndex
        });
      });
    
      myChart.on("mouseout", function () {
        timeTicket && clearInterval(timeTicket);
        timeTicket = setInterval(function () {
          myChart.dispatchAction({
            type: "downplay",
            seriesIndex: 0 //serieIndex的索引值   可以触发多个
          });
          myChart.dispatchAction({
            type: "highlight",
            seriesIndex: 0,
            dataIndex: count
          });
          myChart.dispatchAction({
            type: "showTip",
            seriesIndex: 0,
            dataIndex: count
          });
          count++;
          if (count >= 17) {
            count = 0
          }
        }, 3000);
      });

    通过上面代码可以实现tooltip的轮播效果,并且在鼠标的移入时,不会影响tooltip的出现,不会造成无法查看当前类目的tooltip。

    因为是在Vue项目中,还需进行一次封装,方便被其他模块引用(将代码封装,并命名为tools.js):

    /**
     *  echarts tooltip 自动轮播
     *  @author liuwei
     *  @param myChart  //初始化echarts的实例
     *  @param option   //指定图表的配置项和数据
     *  @param num      //类目数量(原因:循环时达到最大值后,使其从头开始循环)
     *  @param time     //轮播间隔时长
     */
    export function autoHover(myChart, option, num, time) {
      var defaultData = {   //设置默认值
          time: 2000,
          num: 100
      };
      if(!time){
        time = defaultData.time;
      }
      if(!num){
        num = defaultData.num;
      }
    
    
      var count = 0;
      var timeTicket = null;
      timeTicket && clearInterval(timeTicket);
      timeTicket = setInterval(function () {
        myChart.dispatchAction({
          type: "downplay",
          seriesIndex: 0 //serieIndex的索引值   可以触发多个
        });
        myChart.dispatchAction({
          type: "highlight",
          seriesIndex: 0,
          dataIndex: count
        });
        myChart.dispatchAction({
          type: "showTip",
          seriesIndex: 0,
          dataIndex: count
        });
        count++;
        if (count >= num) {
          count = 0
        }
      }, time);
      myChart.on("mouseover", function (params) {
        clearInterval(timeTicket);
        myChart.dispatchAction({
          type: "downplay",
          seriesIndex: 0
        });
        myChart.dispatchAction({
          type: "highlight",
          seriesIndex: 0,
          dataIndex: params.dataIndex
        });
        myChart.dispatchAction({
          type: "showTip",
          seriesIndex: 0,
          dataIndex: params.dataIndex
        });
      });
    
      myChart.on("mouseout", function () {
        timeTicket && clearInterval(timeTicket);
        timeTicket = setInterval(function () {
          myChart.dispatchAction({
            type: "downplay",
            seriesIndex: 0 //serieIndex的索引值   可以触发多个
          });
          myChart.dispatchAction({
            type: "highlight",
            seriesIndex: 0,
            dataIndex: count
          });
          myChart.dispatchAction({
            type: "showTip",
            seriesIndex: 0,
            dataIndex: count
          });
          count++;
          if (count >= 17) {
            count = 0
          }
        }, 3000);
      });
    }
    export default {
      autoHover
    }

    接下来要做的就是在vue文件中引用:

    <template>
      <div class="wrapper">
        <div class="bar" id="bar"></div>
      </div>
    </template>
    
    <script>
    import tools from "tools";  //引入tools.js
    export default {
      components: {},
      props: {},
      data() {
        return {};
      },
      created() {},
      mounted() {
        this.drawRightLine();
      },
      watch: {},
      computed: {},
      methods: {
        drawRightLine() {
          // 基于准备好的dom,初始化echarts实例
          var myChart = echarts.init(document.getElementById("rightLine"));
          // 指定图表的配置项和数据
          var option = {
            title: {
              text: "ECharts 入门示例"
            },
            tooltip: {},
            legend: {
              data: ["销量"]
            },
            xAxis: {
              data: ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"]
            },
            yAxis: {},
            series: [
              {
                name: "销量",
                type: "bar",
                data: [5, 20, 36, 10, 10, 20]
              }
            ]
          };
          // 使用刚指定的配置项和数据显示图表。
          myChart.setOption(option);
          //使用轮播插件,填入相关参数
          tools.autoHover(myChart, option, 17, 3000);
        }
      }
    };
    </script>
    <style scoped>
    .wrapper {
      height: 100%;
       100%;
    }
    .bar {
      height: 100%;
       100%;
    }
    </style>
  • 相关阅读:
    540 Single Element in a Sorted Array 有序数组中的单一元素
    539 Minimum Time Difference 最小时间差
    538 Convert BST to Greater Tree 把二叉搜索树转换为累加树
    537 Complex Number Multiplication 复数乘法
    535 Encode and Decode TinyURL 编码和解码精简URL地址
    532 K-diff Pairs in an Array 数组中差为K的数对
    530 Minimum Absolute Difference in BST 二叉搜索树的最小绝对差
    529 Minesweeper 扫雷游戏
    526 Beautiful Arrangement
    1.5 函数
  • 原文地址:https://www.cnblogs.com/liuwei54/p/10496555.html
Copyright © 2011-2022 走看看