在Element UI的<el-table>组件中,点击子元素不触发父级事件

在Element UI的<el-table>组件中,@row-click事件是绑定在整行上的,这意味着如果点击了表格的任意位置(除非有特定的子元素阻止了事件冒泡),都会触发这个事件。如果你想要在某些子元素上点击时不触发@row-click事件,你需要在这些子元素上阻止事件冒泡。

你可以通过在子元素上添加点击事件并调用event.stopPropagation()方法来实现这一点。event.stopPropagation()会阻止事件进一步冒泡到DOM树中,因此不会触发绑定在更高层次元素(如整行)上的事件。

以下是一个示例,展示了如何在表格的某个子元素(比如一个按钮)上点击时阻止@row-click事件的触发:

复制代码
<template>  
  <div class="content">  
    <el-table :data="tableData" style="width: 100%" @row-click="handleRowClick">  
      <el-table-column prop="date" label="Date" width="180" />  
      <el-table-column prop="name" label="Name" width="180">  
        <template #default="{ row }">  
          <span>{{ row.name }}</span>  
          <el-button type="text" @click.stop="handleClickButton(row)">不触发行点击</el-button>  
        </template>  
      </el-table-column>  
      <el-table-column prop="address" label="Address" />  
    </el-table>  
  </div>  
</template>  
  
<script>  
import { ref } from 'vue';  
  
export default {  
  setup() {  
    const tableData = ref([  
      // ... 表格数据  
    ]);  
  
    // 处理行点击事件的方法  
    const handleRowClick = (row, column, event) => {  
      console.log('行被点击了', row.id);  
    };  
  
    // 处理按钮点击事件的方法  
    const handleClickButton = (row) => {  
      console.log('按钮被点击了,但行点击事件没有触发', row.id);  
    };  
  
    return {  
      tableData,  
      handleRowClick,  
      handleClickButton,  
    };  
  },  
};  
</script>

在这个例子中,使用了#default插槽来自定义name列的渲染。在这个插槽内部,添加了一个文本<span>来显示名字,并添加了一个<el-button>按钮。按钮上绑定了点击事件@click.stop="handleClickButton(row)",其中**.stop修饰符用于阻止事件冒泡** 。这样,当按钮被点击时,只会触发handleClickButton方法,而不会触发绑定在整行上的handleRowClick方法。

相关推荐
ljt27249606611 分钟前
Vue笔记(一)--模板
前端·vue.js·笔记
光影少年4 分钟前
react的useRef 作用:获取DOM、保存可变数据、区别 createRef
前端·javascript·react.js
你很易烊千玺10 小时前
日常练习-数组 字符串常用的场景
前端·javascript·字符串·数组
存在的五月雨11 小时前
Vue3项目一些语法
前端·javascript·react.js
大家的林语冰11 小时前
Node 2026 发布,JS 三大新功能上线,最后一个奇偶版本
前端·javascript·node.js
三*一12 小时前
Mapbox GL JS 自研面要素整形工具开发实录
开发语言·javascript·arcgis·ecmascript
我的世界洛天依12 小时前
胡桃讲编程|续篇!用高数 + JS ES262 硬核解构:求乐正绫的值
javascript
棉猴13 小时前
python海龟绘图之画布与窗口
javascript·python·html·setup·turtle·海龟绘图·screensize
AI_paid_community14 小时前
25k Star 登顶 GitHub:这个专门吃 K 线图长大的 AI,让我意识到之前三年都在裸奔
javascript·claude