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

相关推荐
SuperEugene8 小时前
Vue生态精选篇:Element Plus 的“企业后台常用组件”用法扫盲
前端·vue.js·面试
Neptune18 小时前
JavaScript回归基本功之---类型判断--typeof篇
前端·javascript·面试
进击的尘埃8 小时前
微前端沙箱隔离:qiankun 和 wujie 到底在争什么
javascript
子兮曰9 小时前
后端字段又改了?我撸了一个 BFF 数据适配器,从此再也不怕接口“屎山”!
前端·javascript·架构
颜酱11 小时前
一步步实现字符串计算器:从「转整数」到「带括号与优化」
javascript·后端·算法
比尔盖茨的大脑11 小时前
事件循环底层原理:从 V8 引擎到浏览器实现
前端·javascript·面试
bluceli11 小时前
Vue 3 Composition API深度解析:构建可复用逻辑的终极方案
前端·vue.js
程序员ys11 小时前
前端权限控制设计
前端·vue.js·react.js
卓卓不是桌桌11 小时前
如何优雅地处理 iframe 跨域通信?这是我的开源方案
javascript·架构
滕青山11 小时前
腾讯域名拦截查询 在线工具核心JS实现
前端·javascript·vue.js