vue el-table表格点击某行触发事件&&操作栏点击和row-click冲突问题

文章为本新手菜鸡的问题记录,如有错误和不足还请大佬指正

文章目录


前言

文章主要解决两个问题:

1、点击el-table表格某行,触发事件

2、解决el-table的操作栏点击和row-click冲突问题


一、点击el-table表格某行,触发事件

查阅elementUI参考文档发现table可以通过@row-click事件来管理点击触发事件

c 复制代码
<template>
  <div>
  <el-table
	:data="state.orgTreeData"
	style="width: 100%"
	v-loading="state.loading"
	@row-click="handleClick"
	>
		<el-table-column></el-table-column>
	</table>
	</div>
</template>
<script lang="ts" setup name="admin/org">
const handleClick = (row) => {
  onEdit(row)
}
</script>

二、解决el-table的操作栏点击和row-click冲突问题

1.问题:

点击el-table某一行跳转到详情页,使用row-click(当某一行被点击时会触发该事件)后,会导致点击操作栏的按钮也会触发

例如下图中,点击表格某行跳转使用row-click,会触发左侧操作栏的按钮

2.解决方法

原生标签使用@click.stop,按钮el-button不是原生标签使用@click.native.stop,阻止事件冒泡

代码如下(示例):

c 复制代码
 <el-table-column label="操作" width="220" fixed="right" header-align="center" align="center">
 	<template #default="{ row }">
 		<el-button icon="ele-EditPen" size="small" text type="primary" @click.native.stop="onEdit(row)">编辑</el-button>
        <el-button icon="ele-Clock" size="small" text type="primary" @click.native.stop="onDelay">延期</el-button>
        <el-button icon="ele-Delete" size="small" text type="danger" @click.native.stop="onDelete(row)">删除</el-button>
    </template>
</el-table-column>
相关推荐
机器视觉知识推荐、就业指导10 分钟前
QML 批量创建模块 【Repeater】 组件详解
前端·c++·qml
lmryBC4916 分钟前
golang接口-interface
java·前端·golang
慕斯策划一场流浪22 分钟前
fastGPT—nextjs—mongoose—团队管理之团队列表api接口实现
开发语言·前端·javascript·fastgpt env文件配置·fastgpt团队列表接口实现·fastgpt团队切换api·fastgpt团队切换逻辑
勘察加熊人28 分钟前
forms实现连连看
c#
hvinsion29 分钟前
PPT助手:一款集计时、远程控制与多屏切换于一身的PPT辅助工具
c#·powerpoint·ppt·ppt助手·ppt翻页
LaoZhangAI44 分钟前
【2025最新】Claude免费API完全指南:无需信用卡,中国用户也能用
前端
cypking1 小时前
解决 axios get请求瞎转义问题
vue.js
向阳2561 小时前
SpringBoot+vue前后端分离整合sa-token(无cookie登录态 & 详细的登录流程)
java·vue.js·spring boot·后端·sa-token·springboot·登录流程
hepherd1 小时前
Flask学习笔记 - 模板渲染
前端·flask