在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方法。

相关推荐
YukiMori238 小时前
一个有趣的原型继承实验:为什么“男人也会生孩子”?从对象赋值到构造函数继承的完整推演
前端·javascript
摸鱼的春哥9 小时前
惊!黑客靠AI把墨西哥政府打穿了,海量数据被黑
前端·javascript·后端
小兵张健9 小时前
Playwright MCP 截图标注方案调研(推荐方案1)
前端·javascript·github
我叫黑大帅11 小时前
Vue3和Uniapp的爱恨情仇:小白也能懂的跨端秘籍
前端·javascript·vue.js
None32112 小时前
【NestJs】使用Winston+ELK分布式链路追踪日志采集
javascript·node.js
Qinana12 小时前
从代码到智能体:MCP 协议如何重塑 AI Agent 的边界
前端·javascript·mcp
洋洋技术笔记13 小时前
Vue实例与数据绑定
前端·vue.js
Marshall15113 小时前
zzy-scroll-timer:一个跨框架的滚动定时器插件
前端·javascript
明月_清风14 小时前
打字机效果优化:用 requestAnimationFrame 缓冲高频文字更新
前端·javascript
明月_清风14 小时前
Markdown 预解析:别等全文完了再渲染,如何流式增量渲染代码块和公式?
前端·javascript