1.4.Vue 的模板事件

Vue 的模板事件

1. 最常见和推荐的做法。将复杂的逻辑封装在 methods 中。

<!-- ✅ 正确:调用 methods 中的方法 -->
<button @click="handleClick">点击我</button>
new Vue({methods: {handleClick(event) {// 这里可以写任意语句if (this.isValid) {this.saveData();} else {console.log('数据无效');}// 其他复杂逻辑...}}
});

2. 使用内联表达式(简单逻辑)

对于非常简单的逻辑,可以直接在 @click 后写一个表达式。

<!-- ✅ 正确:使用表达式 -->
<button @click="counter++">增加计数</button>
<button @click="name = 'Vue'">设置名字</button>
<button @click="say('hi')">打招呼</button>
new Vue({data: {counter: 0,name: ''},methods: {say(message) {alert(message);}}
});

3. 使用内联函数调用(带参数或事件)

如果需要传递参数或访问原生事件对象,可以使用内联箭头函数或普通函数调用。

<!-- ✅ 正确:使用内联函数 -->
<button @click="(event) => deleteItem(id, event)">删除</button>
<button @click="() => { if (confirm('确定?')) doSomething() }">确认操作</button>
new Vue({data: {id: 1},methods: {deleteItem(id, event) {console.log('删除 ID:', id, '事件:', event);},doSomething() {// ...}}
});

错误的写法(直接写语句)

以下写法是无效的,会导致错误或不按预期工作:

<!-- ❌ 错误:直接写 if 语句 -->
<button @click="if (ok) { return message }">错误示例</button><!-- ❌ 错误:直接写 for 循环 -->
<button @click="for (let i=0; i<10; i++) { console.log(i) }">错误示例</button><!-- ❌ 错误:直接写 var 声明 -->
<button @click="var a = 1; a + 2">错误示例</button>

总结

  • 在 v-on 事件绑定中,不能直接写 ifforvar 等 JavaScript 语句
  • 可以写:
    • 方法调用@click="methodName" (推荐用于复杂逻辑)
    • 简单表达式@click="counter++" 或 @click="name='Vue'"
    • 内联函数调用@click="(event) => handler(id, event)" 或 @click="() => { /* 简单逻辑 */ }"
  • 复杂逻辑应始终放在 methods 选项中,并在事件绑定中调用该方法。

事件对象传递

处理事件时可以使用原生的 event 对象,也可以通过 $event 来引用这个对象。

1.直接使用 event

假设我们有一个按钮,点击时调用一个方法,并且该方法需要访问事件对象:

<button @click="handleClick">点击我</button>

对应的 Vue 实例方法可能如下所示:

new Vue({el: '#app',methods: {handleClick(event) { // 直接将事件对象作为参数传递console.log('事件类型:', event.type); // 输出 'click'console.log('事件目标:', event.target); // 输出触发事件的元素}}
});

在这个例子中,Vue 自动将触发事件的原生 DOM 事件对象作为第一个参数传递给 handleClick 方法。这种方式清晰直观,适合于不需要额外参数的情况。

2.使用 $event

$event 是 Vue 提供的一个特殊变量,用于在内联事件处理器表达式中显式地引用原生 DOM 事件对象。这种方式通常在你需要同时传递自定义参数并访问事件对象时使用。

示例

假设我们有一个按钮,点击时不仅要传递某个特定参数(比如 id),还需要访问点击事件的信息:

<button @click="deleteItem(id, $event)">删除</button>

对应的 Vue 实例:

new Vue({el: '#app',data: {id: 1},methods: {deleteItem(id, event) { // 同时接收自定义参数和事件对象console.log('要删除的ID:', id);console.log('事件对象:', event);// 可以在这里执行其他操作,例如阻止默认行为或停止事件冒泡event.stopPropagation();}}
});

在这个例子中,当我们点击按钮时,deleteItem 方法会被调用,并且会接收到两个参数:一个是 id,另一个是 $event,即原生的 DOM 事件对象。这里的关键点在于通过 $event 显式地将事件对象传递给了方法。

3.使用 内置的event

<button @click="(event) => deleteItem(id, event)">删除</button>

在第一节体验vue中,我们直接使用 event传递. 会有一个弊端.如果event是 data的成员.那么event就不能正确指向dom事件对象.

<button v-on:click="greet(event)">event测试</button>new Vue({el: '#example',data: {event: 'Hello Vue!',},methods: {             greet: function (e) {alert(e);             }}
}

  1. $event (Vue 特殊变量)

    • 这是 Vue.js 框架提供的一个特殊变量
    • 总是指向被触发的原生 DOM 事件对象(例如 MouseEventKeyboardEvent 等)。
    • 无论你在 v-on 指令的值中如何使用它,$event 的值就是那个原始的、由浏览器生成的事件对象。
  2. event (JavaScript 变量/标识符)

    • 这只是一个普通的 JavaScript 变量名标识符
    • 它的值取决于当前 JavaScript 作用域中名为 event 的变量是什么。

    • 在 Vue 的模板表达式里,event 会被当作一个变量来查找。它可能指向:

      • window.event (如果存在)。
      • 一个在 Vue 实例 data 或 methods 中定义的名为 event 的变量

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

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

相关文章

SQLite 子查询详解

SQLite 子查询详解 引言 SQLite 是一种轻量级的数据库&#xff0c;以其简单、易用和跨平台而著称。在数据库查询中&#xff0c;子查询是一个非常重要的概念&#xff0c;它允许我们在查询中使用查询结果。本文将详细讲解 SQLite 中的子查询&#xff0c;包括其定义、用法以及在实…

可以组成网络的服务器 - 华为OD统一考试(JavaScript 题解)

题目描述 在一个机房中,服务器的位置标识在n*m的整数矩阵网格中,1表示单元格上有服务器,0表示没有。如果两台服务器位于同一行或者同一列中紧邻的位置,则认为它们之间可以组成一个局域网,请你统计机房中最大的局域网包含的服务器个数。 输入描述 第一行输入两个正整数,…

redis,MongoDB等未授权访问靶场复现

redis未授权访问在docker中启动vulhub对应的靶场目录&#xff1a;cd /vulhub-master/redis/4-unacc在kali上安装redis程序进行服务连接安装redis apt-get install redis redis链接 redis-cli -h IP -p 端口输入info可以查看信息接下来我们使用redis-rogue-server来获取命令执行…

设计模式:代理模式 Proxy

目录问题解决方案结构代码代理是一种结构型设计模式&#xff0c;让你能够提供对象的替代品或其占位符。代理控制着对于原对象的访问&#xff0c;并允许在将请求提交给对象前后进行一些处理。 问题 为什么要控制对于某个对象的访问呢&#xff1f; 举个例子&#xff1a; 有这样一…

Linux零基础Shell教学全集(可用于日常查询语句,目录清晰,内容详细)(自学尚硅谷B站shell课程后的万字学习笔记,附课程链接)

此文章为学习了 尚硅谷B站课程 后的学习笔记 【尚硅谷】Shell脚本从入门到实战_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1hW41167NW/?spm_id_from333.337.search-card.all.click&vd_source68e0bbe20c8b1102b59ced40f67db628注意&#xff1a;需要先学Linux基础…

GitLab 中的分支和标签的定义及操作

&#xff08;一&#xff09;GitLab 中的分支和标签的定义及操作 1. 分支&#xff08;Branch&#xff09; 定义&#xff1a; 分支是代码仓库中的独立开发路径&#xff0c;允许你在不影响主线&#xff08;通常是 main 或 master 分支&#xff09;的情况下&#xff0c;进行实验、开…

第2章 cmd命令基础:常用基础命令(3)

Hi~ 我是李小咖&#xff0c;主要从事网络安全技术开发和研究。 本文取自《李小咖网安技术库》&#xff0c;欢迎一起交流学习&#x1fae1;&#xff1a;https://imbyter.com 本节介绍的命令有显示系统信息&#xff08;systeminfo&#xff09;、启动指定程序&#xff08;start&am…

RabbitMQ 发送方确认的两大工具 (With Spring Boot)

核心概念解析 发布者确认机制的核心思想是&#xff1a;将消息投递的可靠性从“尽力而为”提升为“契约保证”。生产者不再是“发后不理”&#xff0c;而是与 Broker 建立一个双向的沟通渠道。 在 Spring AMQP 的封装下&#xff0c;这个机制主要由两个回调接口实现&#xff1a; …

KONG API Gateway中的核心概念

在使用Kong API Gateway&#xff08;API网关&#xff09;时&#xff0c;理解其核心概念是掌握其工作原理的基础。这些概念既体现了Kong的设计哲学&#xff0c;也决定了它如何适配复杂的API管理场景&#xff08;如微服务、多团队协作等&#xff09;。本文将系统梳理Kong的核心概…

如何解决pip安装报错ModuleNotFoundError: No module named ‘jupyterlab’问题

【Python系列Bug修复PyCharm控制台pip install报错】如何解决pip安装报错ModuleNotFoundError: No module named ‘jupyterlab’问题 摘要 在开发过程中&#xff0c;我们经常会遇到各种模块安装的问题&#xff0c;尤其是在使用PyCharm时&#xff0c;经常会遇到pip install时的…

3 运算符与表达式

运算符&#xff1a;对字面量或者变量进行操作的符号 表达式&#xff1a;用运算符把字面量或者变量连接起来符合java语法的式子就可以称作表达式不同运算符连接的表达式体现的是不同类型的表达式int a 10; int b 20; int c a b;&#xff1a;运算符&#xff0c;并且是算术运算…

MySQL的单行函数:

目录 函数的理解&#xff1a; MySQL的内置函数及分类&#xff1a; 单行函数&#xff1a; 数值函数&#xff1a; 基本函数&#xff1a; 角度与弧度互换函数&#xff1a; 三角函数&#xff1a; 指数与对数&#xff1a; 进制转换&#xff1a; 字符串函数&#xff1a; 日…

设计模式(二十一)行为型:状态模式详解

设计模式&#xff08;二十一&#xff09;行为型&#xff1a;状态模式详解状态模式&#xff08;State Pattern&#xff09;是 GoF 23 种设计模式中的行为型模式之一&#xff0c;其核心价值在于允许一个对象在其内部状态改变时改变其行为&#xff0c;使得对象看起来像是修改了它的…

深入理解 Doris Compaction:提升查询性能的幕后功臣

在 Doris 的数据存储与查询体系里&#xff0c;Compaction 是保障查询效率、优化存储结构的关键机制。如果你好奇 Doris 如何在高频写入后仍能高效响应查询&#xff0c;或是想解决数据版本膨胀带来的性能问题&#xff0c;这篇关于 Compaction 的深度解析值得收藏 &#x1f447; …

css 实现虚线效果的多种方式

使用边框实现虚线 通过设置元素的边框样式来实现虚线效果。以下为示例代码: .dashed {border: 1px dashed black; }使用 CSS 伪元素实现虚线 使用伪元素来模拟虚线的效果。以下为示例代码: .dashed::before {content: "";display: block;height: 1px;border-bo…

深入剖析 RocketMQ 分布式事务:原理、流程与实践

Apache RocketMQ 是一种分布式消息队列系统&#xff0c;支持分布式事务消息&#xff0c;以确保在分布式系统中数据的一致性。它通过一种基于两阶段提交(2PC)的机制结合补偿逻辑来实现分布式事务的最终一致性。以下是对 RocketMQ 分布式事务的详细讲解&#xff0c;包括其核心概念…

具身智能 自动驾驶相关岗位的技术栈与能力地图

一、硬技能技术栈&#xff08;优先级排序&#xff09; 1. 核心领域技术&#xff08;★★★★★&#xff09;技术方向具体技能学习建议大模型实战- VLA架构&#xff08;RT-2、PaLM-E&#xff09;开发/微调- 多模态对齐&#xff08;CLIP、Flamingo&#xff09;- 生成式策略&#…

实现了加载 正向 碰撞 雅可比 仿真

""" # 此示例从 URDF 文件中加载一个 UR10 机械臂的模型 # 随后演示 Pinocchio 库的基本功能,如正向运动学计算 # 雅可比矩阵计算、碰撞检测以及动力学仿真 """ # 导入 meshcat 的几何模块,用于创建和管理可视化的几何对象 import meshcat.geo…

【0基础PS】PS工具详解--画笔工具

目录前言一、画笔工具的位置与快捷键​二、画笔工具选项栏设置​三、画笔工具的进阶应用​四、常见问题及解决方法​总结前言 在 Photoshop 的众多工具中&#xff0c;画笔工具无疑是极具创造力和实用性的工具之一。无论是进行图像绘制、照片修饰&#xff0c;还是特效制作&…

window10和ubuntu22.04双系统之卸载ubuntu系统

window10和ubuntu22.04双系统之卸载ubuntu系统&#xff09;1. 删除Ubuntu系统占用的磁盘分区&#xff08;在Windows下操作&#xff09;2. 删除ubuntu开机引导项1. winr出来终端提示框后输入2. 然后会在命令行中显示电脑的硬盘列表&#xff0c;输入命令选择安装Windows的那个硬盘…