避免事件“穿透”——Vue 中事件冒泡的理解与解决方案

一、事件冒泡是什么?

事件冒泡指的是:当某个元素上的事件被触发后,事件会从该元素向其父级、祖先元素一直“冒泡”传递,直到 document。这意味着,如果父元素绑定了点击事件,子元素触发点击时也可能顺带触发父元素的点击逻辑

<template><div class="card" @click="handleCardClick"><button @click="handleButtonClick">解除绑定</button></div>
</template>

点击按钮时,handleButtonClick 会执行,但由于事件冒泡,handleCardClick 也会被触发。

这就是我们常说的 点击“穿透” 问题。

二、如何阻止事件冒泡? 

只需要加上 .stop,就能阻止事件向上传播:

<button @click.stop="handleButtonClick">解除绑定</button>

三、原生写法对比

如果你是用原生 JavaScript 监听事件,那就需要显式调用 stopPropagation()

button.addEventListener('click', function(event) {event.stopPropagation(); // 阻止冒泡
});

四、总结

  • Vue 中事件“穿透”问题,本质是事件冒泡。

  • 使用 .stop 可以优雅地阻止冒泡。

  • 原生写法则用 event.stopPropagation()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/78210.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Java面试笔记:进阶】17.一个线程两次调用start()方法会出现什么情况?

1. 线程启动与异常 线程启动:Java 线程只能启动一次,通过调用 Thread 对象的 start() 方法。多次启动的后果:如果尝试第二次调用 start() 方法,会抛出 IllegalThreadStateException 运行时异常。(1) 代码示例 public class ThreadStartDemo {public static void main(Stri…

Flask + ajax上传文件(一)

一、概述 本教程将教你如何使用Flask后端和AJAX前端实现文件上传功能,包含完整的代码实现和详细解释。 二、环境准备 1. 所需工具和库 Python 3.xFlask框架jQuery库Bootstrap(可选,用于美化界面)2. 安装Flask pip install flask三、项目结构 upload_project/ ├── a…

NHANES指标推荐:TyG-WHtR

文章题目&#xff1a;Can cardiovascular health and its modifiable healthy lifestyle offset the increased risk of all-cause and cardiovascular deaths associated with insulin resistance? DOI&#xff1a;10.1186/s12933-025-02674-z 中文标题&#xff1a;心血管健康…

OpenHarmony 开源鸿蒙北向开发——hdc工具使用及常用命令(持续更新)

hdc&#xff08;OpenHarmony Device Connector&#xff09;是为开发人员提供的用于设备连接调试的命令行工具&#xff0c;该工具需支持部署在 Windows/Linux/Mac 等系统上与 OpenHarmony 设备&#xff08;或模拟器&#xff09;进行连接调试通信。简单来讲&#xff0c;hdc 是 Op…

MCP servers源码详细解析

MCP servers详细解析 Model Context Protocol (MCP) 是一个标准化协议&#xff0c;用于让大型语言模型&#xff08;LLMs&#xff09;通过结构化服务器安全地与工具和数据源交互。项目提供了 参考实现、官方集成和社区贡献的服务器&#xff0c;支持数据库、API、文件系统等场景…

美乐迪电玩大厅加载机制与 RoomList 配置结构分析

本篇为《美乐迪电玩全套系统搭建》系列的第三篇&#xff0c;聚焦大厅与子游戏的动态加载机制&#xff0c;深入解析 roomlist.json 的数据结构、解析流程、入口配置方式与自定义接入扩展技巧。通过本篇内容&#xff0c;开发者可实现自由控制子游戏接入与分发策略。 一、RoomList…

HarmonyOS-ArkUI: 属性动画:animation

HarmonyOS-ArkUI:关键帧动画 keyFrameAnimateTo-CSDN博客 HarmonyOS-ArkUI: animateTo 显式动画-CSDN博客 至今为止,已经讲了两个动画了(显式动画,关键帧动画如链接所示),这个属性动画是第三个。鸿蒙的属性动画,和Android中的属性动画,迥异,也就是名字不同罢了。所以之…

强化学习(Reinforcement Learning, RL)和深度学习(Deep Learning, DL)

强化学习&#xff08;Reinforcement Learning, RL&#xff09;和深度学习&#xff08;Deep Learning, DL&#xff09;是人工智能领域两个重要的研究方向&#xff0c;虽然二者可以结合&#xff08;如深度强化学习&#xff09;&#xff0c;但其核心思想、目标和应用场景存在本质区…

处理任务“无需等待”:集成RabbitMQ实现异步通信与系统解耦

在前几篇文章中&#xff0c;我们构建的Web应用遵循了一个常见的同步处理模式&#xff1a;用户发出HTTP请求 -> Controller接收 -> Service处理&#xff08;可能涉及数据库操作、调用其他内部方法&#xff09;-> Controller返回HTTP响应。这个流程简单直接&#xff0c;…

Obsidian和Ollama大语言模型的交互过程

之前的文章中介绍了Obsidian配合Ollama的使用案例&#xff0c;那么它们是如何配合起来的呢&#xff1f;其实这个问题并不准确&#xff0c;问题的准确描述应该是Obsidian的Copilot插件是如何与Ollama大语言模型交互的。因为Obsidian在这里只是一个载体&#xff0c;核心功能还是C…

4.1 融合架构设计:LLM与Agent的协同工作模型

大型语言模型&#xff08;Large Language Models, LLMs&#xff09;与智能代理&#xff08;Agent&#xff09;的融合架构已成为人工智能领域推动企业智能化的核心技术。这种协同工作模型利用LLM的语言理解、推理和生成能力&#xff0c;为Agent提供强大的知识支持&#xff0c;而…

龙虎榜——20250424

指数依然是震荡走势&#xff0c;接下来两天调整的概率较大 2025年4月24日龙虎榜行业方向分析 一、核心主线方向 化工&#xff08;新能源材料产能集中&#xff09; • 代表标的&#xff1a;红宝丽&#xff08;环氧丙烷/锂电材料&#xff09;、中欣氟材&#xff08;氟化工&…

Linux 服务器运维常用命令大全

1.基础命令 1.1 文件与目录操作 ls -l #列出文件详细信息 ls -a #显示隐藏文件 cd /path/to/directory #切换目录 pwd #显示当前工作目录 mkdir dirname #创建目录 rm -rf dirname #删除…

动态渲染页面智能嗅探:机器学习判定AJAX加载触发条件

本文提出了一种基于机器学习的智能嗅探机制&#xff0c;革新性地应用于自动判定动态渲染页面中AJAX加载的最佳触发时机。系统架构采用先进模块化拆解设计&#xff0c;由请求分析模块、机器学习判定模块、数据采集模块和文件存储模块四大核心部分构成。在核心代码示例中&#xf…

sql高级之回表

避免回表是数据库查询优化的核心目标之一&#xff0c;指通过索引直接获取查询所需的全部数据&#xff0c;无需根据索引结果再回主表&#xff08;数据行&#xff09;读取其他字段&#xff0c;从而减少磁盘 I/O 和计算开销。以下是详细解释&#xff1a; 1. 什么是回表&#xff1…

第十一届机械工程、材料和自动化技术国际会议(MMEAT 2025)

重要信息 官网&#xff1a;www.mmeat.net 时间&#xff1a;2025年06月23-25日 地点&#xff1a;中国-深圳 部分展示 征稿主题 智能制造和工业自动化 复合材料与高性能材料先进制造技术 自动化机器人系统 云制造与物联网集成 精密制造技术 智能生产线优化 实时数据分析与过…

动态自适应分区算法(DAPS)设计流程详解

动态自适应分区算法&#xff08;Dynamic Adaptive Partitioning System, DAPS&#xff09;是一种通过实时监测系统状态并动态调整资源分配策略的智能算法&#xff0c;广泛应用于缓存优化、分布式系统、工业制造等领域。本文将从设计流程的核心步骤出发&#xff0c;结合数学模型…

从入门到精通:CMakeLists.txt 完全指南

从入门到精通&#xff1a;CMakeLists.txt 完全指南 CMake 是一个跨平台的自动化构建系统&#xff0c;它使用名为 CMakeLists.txt 的配置文件来控制软件的编译过程。无论你是刚接触 CMake 的新手&#xff0c;还是希望提升 CMake 技能的中级开发者&#xff0c;这篇指南都将带你从…

CPT204 Advanced Obejct-Oriented Programming 高级面向对象编程 Pt.8 排序算法

文章目录 1. 排序算法1.1 冒泡排序&#xff08;Bubble sort&#xff09;1.2 归并排序&#xff08;Merge Sort&#xff09;1.3 快速排序&#xff08;Quick Sort&#xff09;1.4 堆排序&#xff08;Heap Sort&#xff09; 2. 在面向对象编程中终身学习2.1 记录和反思学习过程2.2 …

【element plus】解决报错error:ResizeObserver loop limit exceeded的问题

当我们在使用element plus框架时&#xff0c;有时会遇到屏幕突然变暗&#xff0c;然后来一句莫名其妙的报错ResizeObserver loop limit exceeded&#xff0c;其实这是因为改变屏幕大小时el-table导致的报错 网上给出了几种解决方案&#xff0c;我试了其中两种可以实现 方案一&…