原文链接

设置tooltip

enterable: true, //允许鼠标进入提示悬浮层中,triggeron:‘click’,//提示框触发的条件 mousemove鼠标移动时触发 click鼠标点击时触发 'mousemove|click’同时鼠标移动和点击时触发

tooltip: {
        // 提示框组件
        show: true, // 显示提示框组件
        trigger: "item", // 触发类型
        triggerOn: "mousemove", // 出发条件
        //   formatter: "名称:{b}<br/>坐标:{c}",
        enterable: true, //允许鼠标进入提示悬浮层中
        showContent: true,
        triggerOn: "click", //提示框触发的条件  mousemove鼠标移动时触发 click鼠标点击时触发  'mousemove|click'同时鼠标移动和点击时触发
        //   confine: true, //把toolTip限制在图表的区域内
        className: "areaTool",
        // hideDelay: 100000, //延时消失时间
        formatter: (item) => {
          this.hookToolTip = item;
          // 经纬度太长需要对位数进行截取显示,保留七位小数
          // 需要绑定点击事件
          var tipHtml = "";
          tipHtml =
            '<div style="width:2.5rem;height:80%;background:rgba(22,80,158,0.8);border:0.0125rem solid rgba(7,166,255,0.7)">' +
            '<div style="width:100%;height:0.375rem;line-height:0.375rem;border-bottom:0.025rem solid rgba(7,166,255,0.7);">' +
            '<i style="display:inline-block;width:0.125rem;height:0.125rem;background:#16d6ff;border-radius:0.5rem;">' +
            "</i>" +
            '<span id="btn-tooltip" style="margin-left:0.125rem;color:#fff;font-size:0.2rem;cursor:pointer">' +   
            item.name +
            "</span>" +
            "</div>" +
            '<div style="padding:0.1875rem;text-align: left;">' +
            '<p style="color:#fff;font-size:0.15rem;">' +
            '<i style="display:inline-block;width:0.1rem;height:0.1rem;background:#16d6ff;border-radius:0.5rem;margin:0 0.1rem">' +
            "</i>" +
            "经度" +
            '<span style="color:#11ee7d;margin:0 0.075rem;">' +
            item.value[0].substr(0, 11) +
            "</span>" +
            "</p>" +
            '<p style="color:#fff;font-size:0.15rem;">' +
            '<i style="display:inline-block;width:0.1rem;height:0.1rem;background:#16d6ff;border-radius:0.5rem;margin:0 0.1rem">' +
            "</i>" +
            "纬度" +
            '<span style="color:#11ee7d;margin:0 0.075rem;">' +
            item.value[1].substr(0, 11) +
            "</span>" +
            "</p>" +
            '<p style="color:#fff;font-size:0.15rem;">' +
            '<i style="display:inline-block;width:0.1rem;height:0.1rem;background:#16d6ff;border-radius:0.5rem;margin:0 0.1rem">' +
            "</i>" +
            "考场数" +
            '<span style="color:#11ee7d;margin:0 0.075rem;">' +
            item.componentIndex +
            "</span>" +
            "个" +
            "</p>" +
            '<p style="color:#fff;font-size:0.15rem;">' +
            '<i style="display:inline-block;width:0.1rem;height:0.1rem;background:#16d6ff;border-radius:0.5rem;margin:0 0.1rem">' +
            "</i>" +
            "监考教师" +
            '<span style="color:#11ee7d;margin:0 0.075rem;">' +
            item.componentIndex +
            "</span>" +
            "个" +
            "</p>";

          return tipHtml;
        },
      },

定义hookToolTip变量

在formatter中给hookToolTip赋值,添加一个id,然后通过watch去检测dom元素,可以通过onclick去绑定事件,也可以通过addEventListerner去注册事件

watch: {
  hookToolTip: {
    handler(newVal, oldVal) {
      console.log(newVal, oldVal, "---------watch");
      let tooltipButton = document.querySelectorAll("#btn-tooltip");
      //通过onclick注册事件 querySelectorAll获取的元素是一个数组
      if (tooltipButton.length > 0) {
        tooltipButton[0].onclick = this.pointNameClick;
      }
      // 通过addEventListener注册事件
      for (let i = 0; i < tooltipButton.length; i++) {
        tooltipButton[i].addEventListener("click", this.chartClick);
      }
    },
    //   immediate: true,
    //   deep: true,
  },
},

在methods中添加方法

methods: {
  chartClick() {
    console.log(
      this.hookToolTip,
      "-------addEventList",
      this.hookToolTip.name
    );
  },
},
GitHub 加速计划 / vu / vue
108
18
下载
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
最近提交(Master分支:3 个月前 )
9e887079 [skip ci] 1 年前
73486cb5 * chore: fix link broken Signed-off-by: snoppy <michaleli@foxmail.com> * Update packages/template-compiler/README.md [skip ci] --------- Signed-off-by: snoppy <michaleli@foxmail.com> Co-authored-by: Eduardo San Martin Morote <posva@users.noreply.github.com> 1 年前
Logo

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。

更多推荐