当前位置: 首页 > article >正文

vue3+ts el-table 鼠标移动到某单元格内时就显示 tooltip

在Vue 3和Element Plus中,要在鼠标移动到表格某个单元格上时显示tooltip,可以使用el-tooltip组件,并结合表格的cell-mouse-entercell-mouse-leave事件。

<template>
  <el-table
    :data="tableData"
    @cell-mouse-enter="handleCellMouseEnter"
    @cell-mouse-leave="handleCellMouseLeave"
  >
    <el-table-column prop="date" label="日期" width="180"></el-table-column>
    <el-table-column prop="name" label="姓名" width="180"></el-table-column>
    <el-table-column prop="address" label="地址" width="200">
      <template #default="{ row, column }">
        <el-tooltip
          :content="row[column.property]"
          v-model:visible="tooltipVisible[column.id]"
          placement="top"
        >
          <span>{{ row[column.property] }}</span>
        </el-tooltip>
      </template>
    </el-table-column>
  </el-table>
</template>
 
<script setup lang="ts">
import { ref } from 'vue';
 
interface TableData {
  date: string;
  name: string;
  address: string;
}
 
const tableData: TableData[] = [
  { date: '2016-05-02', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄' },
  // ...更多数据
];
 
const tooltipVisible = ref<{ [key: string]: boolean }>({});
 
const handleCellMouseEnter = (row: TableData, column: any, cell: HTMLElement, event: MouseEvent) => {
  tooltipVisible.value[column.id] = true;
};
 
const handleCellMouseLeave = (row: TableData, column: any, cell: HTMLElement, event: MouseEvent) => {
  tooltipVisible.value[column.id] = false;
};
</script>

在这个示例中,我们定义了一个tooltipVisible响应式对象来跟踪每列的tooltip显示状态。handleCellMouseEnterhandleCellMouseLeave方法分别在鼠标移入和移出单元格时设置对应列的tooltip显示状态。

el-table-column中,我们使用#default插槽自定义列模板,并在模板内部包裹了el-tooltip组件。el-tooltipcontent属性绑定当前单元格的内容,v-model:visible属性绑定tooltipVisible对象中对应列的显示状态。这样,当鼠标移入单元格时,对应的tooltip就会显示出来。

 


http://www.kler.cn/a/286140.html

相关文章:

  • @antv/g6 业务场景:流程图
  • 电子邮件混淆策略逃避安全保护
  • 在 VS Code 中使用 Git 源代码管理【Mac 版】
  • 宏定义define,内联函数inline,typedef
  • 完美解决node-sass@4.14.1 postinstall: `node scripts/build.js` 问题
  • Springboot中使用Elasticsearch(部署+使用+讲解 最完整)
  • 双臂机器人协作/合作阻抗建模及其控制实现(Dual-Arm Cooperative)
  • Vue 3 中 `async` 函数的示例
  • 考研系列-数据结构冲刺课复习笔记(下)
  • 【iOS】通过第三方库Masonry实现自动布局
  • Llama与ChatGPT的优劣解析
  • saToken的集成和使用
  • 二叉树的最大深度(LeetCode)
  • 数据结构---单链表(常见的复杂操作)
  • 多参数遥测终端科技守护水电站生态流量下泄
  • 对字符、字符串的研究
  • PHP 语法
  • Redis从入门再到入门(中)
  • Java算法之插入排序(Insertion Sort)
  • 16:螺丝孔和MARK点布局