【Vue】`v-on` 指令详解:事件绑定与处理的全面指南
文章目录
- 一、`v-on` 指令概述
- 缩写语法
- 二、`v-on` 的基本用法
- 1. 绑定方法
- 2. 内联处理器
- 三、`v-on` 指令的高级用法
- 1. 事件修饰符
- `.stop`
- `.prevent`
- `.capture`
- `.self`
- `.once`
- 2. 按键修饰符
- `.enter`
- 自定义按键修饰符
- 3. 系统修饰符
- 四、`v-on` 指令的实际应用
- 1. 表单处理
- 模板部分 (`<template>`)
- 脚本部分 (`<script>`)
- 2. 动态组件
- 模板部分 (`<template>`)
- 脚本部分 (`<script>`)
- 3. 事件总线
- 五、`v-on` 指令的注意事项
- 1. 事件解绑
- 2. 事件命名
在 Vue.js 框架中,
v-on
是一个非常重要的指令,用于绑定事件监听器并处理用户交互。本文将详细介绍v-on
指令的用法、常见事件、修饰符及其在实际项目中的应用,帮助开发者更好地理解和使用这一强大工具。
一、v-on
指令概述
v-on
是 Vue.js 用于事件监听的指令,可以绑定原生 DOM 事件或自定义事件。其基本语法如下:
<element v-on:event="handler"></element>
其中,event
是要监听的事件类型,handler
是事件处理函数。
缩写语法
为了简洁,Vue.js 提供了 v-on
指令的缩写形式,用 @
符号代替:
<element @event="handler"></element>
例如,绑定点击事件的写法:
<button v-on:click="handleClick">点击我</button>
<!-- 缩写 -->
<button @click="handleClick">点击我</button>
二、v-on
的基本用法
1. 绑定方法
可以将 v-on
指令绑定到一个方法,方法将在事件触发时执行:
<template><button @click="sayHello">点击我</button>
</template><script>
export default {methods: {sayHello() {alert('Hello!');}}
}
</script>
在这个示例中,点击按钮时会触发 sayHello
方法,并显示一个警告框。
2. 内联处理器
除了绑定方法外,还可以直接在 v-on
中使用内联 JavaScript 表达式:
<template><button @click="count++">点击次数: {{ count }}</button>
</template><script>
export default {data() {return {count: 0}}
}
</script>
在这个示例中,每次点击按钮时,count
会递增。
三、v-on
指令的高级用法
1. 事件修饰符
Vue.js 提供了一些事件修饰符,用于简化常见的事件处理逻辑。
.stop
阻止事件传播:
<template><div @click="outerClick"><button @click.stop="innerClick">点击我</button></div>
</template><script>
export default {methods: {outerClick() {alert('外层点击');},innerClick() {alert('内层点击');}}
}
</script>
在这个示例中,点击按钮时只会触发 innerClick
,不会触发 outerClick
。
.prevent
阻止默认行为:
<template><form @submit.prevent="handleSubmit"><button type="submit">提交</button></form>
</template><script>
export default {methods: {handleSubmit() {alert('表单已提交');}}
}
</script>
在这个示例中,点击提交按钮时会触发 handleSubmit
方法,但不会刷新页面。
.capture
使用捕获模式:
<template><div @click.capture="outerClick"><button @click="innerClick">点击我</button></div>
</template><script>
export default {methods: {outerClick() {alert('外层点击');},innerClick() {alert('内层点击');}}
}
</script>
在这个示例中,outerClick
会在 innerClick
之前触发。
.self
仅在事件目标是当前元素自身时触发处理函数:
<template><div @click.self="handleClick"><button>点击我</button></div>
</template><script>
export default {methods: {handleClick() {alert('div 点击');}}
}
</script>
在这个示例中,点击按钮不会触发 handleClick
方法。
.once
只触发一次事件处理器:
<template><button @click.once="handleClick">点击一次</button>
</template><script>
export default {methods: {handleClick() {alert('按钮点击');}}
}
</script>
在这个示例中,按钮点击事件处理器只会触发一次。
2. 按键修饰符
Vue.js 提供了一些按键修饰符,用于处理键盘事件。
.enter
仅在按下回车键时触发:
<template><input @keyup.enter="submit">
</template><script>
export default {methods: {submit() {alert('提交');}}
}
</script>
在这个示例中,仅在按下回车键时会触发 submit
方法。
自定义按键修饰符
可以使用自定义按键修饰符,例如:
<template><input @keyup.13="submit">
</template><script>
export default {methods: {submit() {alert('提交');}}
}
</script>
在这个示例中,按下键码为 13(即回车键)时会触发 submit
方法。
3. 系统修饰符
系统修饰符用于辅助处理系统键(如 Ctrl
、Alt
、Shift
等):
<template><input @keyup.ctrl.enter="submit">
</template><script>
export default {methods: {submit() {alert('提交');}}
}
</script>
在这个示例中,仅在同时按下 Ctrl
和 Enter
键时会触发 submit
方法。
四、v-on
指令的实际应用
1. 表单处理
在表单处理中,v-on
指令可以用于处理各种用户输入事件:
<template><form @submit.prevent="handleSubmit"><input v-model="username" @input="validateUsername"><p v-if="error">{{ error }}</p><button type="submit">提交</button></form>
</template><script>
export default {data() {return {username: '',error: ''}},methods: {validateUsername() {this.error = this.username.length < 3 ? '用户名至少3个字符' : '';},handleSubmit() {if (!this.error) {alert(`提交的用户名:${this.username}`);}}}
}
</script>
在这个示例中,通过 v-on
绑定 input
和 submit
事件,实现表单验证和提交功能。
详细解释:
模板部分 (<template>
)
<template><form @submit.prevent="handleSubmit"><input v-model="username" @input="validateUsername"><p v-if="error">{{ error }}</p><button type="submit">提交</button></form>
</template>
<form @submit.prevent="handleSubmit">
:这里使用v-on
指令的缩写@
来绑定submit
事件,同时使用.prevent
修饰符阻止表单的默认提交行为。这样在表单提交时会调用handleSubmit
方法,但不会刷新页面。<input v-model="username" @input="validateUsername">
:这里使用v-model
指令实现数据双向绑定,将输入框的值绑定到组件的username
数据属性。同时,使用@input
事件监听器,当用户输入时会调用validateUsername
方法进行用户名验证。<p v-if="error">{{ error }}</p>
:这里使用v-if
指令,如果error
数据属性有值,则显示错误信息。<button type="submit">提交</button>
:这是一个提交按钮,点击后会触发表单的submit
事件。
脚本部分 (<script>
)
<script>
export default {data() {return {username: '', // 存储用户名的输入值error: '' // 存储错误信息}},methods: {validateUsername() {// 如果用户名长度小于3个字符,设置错误信息;否则清空错误信息this.error = this.username.length < 3 ? '用户名至少3个字符' : '';},handleSubmit() {// 如果没有错误信息,弹出提示框显示提交的用户名if (!this.error) {alert(`提交的用户名:${this.username}`);}}}
}
</script>
data()
:定义了组件的响应式数据属性,包括username
和error
。username
用于存储用户输入的用户名,error
用于存储错误信息。methods
:定义了两个方法validateUsername
和handleSubmit
。validateUsername()
:这个方法在每次输入框内容改变时触发,用于验证用户名的长度。如果用户名长度小于 3 个字符,则设置error
属性为'用户名至少3个字符'
,否则清空error
。handleSubmit()
:这个方法在表单提交时触发。它首先检查error
属性是否为空,如果为空则表示用户名有效,此时弹出提示框显示提交的用户名。
2. 动态组件
在动态组件中,v-on
指令可以用于处理组件之间的事件通信:
<template><div><child-component @custom-event="handleCustomEvent"></child-component></div>
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},methods: {handleCustomEvent(payload) {alert(`收到子组件事件:${payload}`);}}
}
</script>
在这个示例中,父组件通过 v-on
监听子组件的自定义事件 custom-event
,并在事件触发时执行 handleCustomEvent
方法。
模板部分 (<template>
)
<template><div><child-component @custom-event="handleCustomEvent"></child-component></div>
</template>
<child-component @custom-event="handleCustomEvent"></child-component>
:这里定义了一个子组件<child-component>
并通过v-on
指令(缩写为@
)监听一个名为custom-event
的自定义事件。当子组件触发这个事件时,会调用父组件的方法handleCustomEvent
。
脚本部分 (<script>
)
<script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},methods: {handleCustomEvent(payload) {alert(`收到子组件事件:${payload}`);}}
}
</script>
import ChildComponent from './ChildComponent.vue';
:这行代码导入了子组件ChildComponent
。components: { ChildComponent }
:在父组件中注册子组件。methods
:定义了一个方法handleCustomEvent
,用于处理子组件触发的custom-event
事件。handleCustomEvent(payload)
:当custom-event
事件被触发时,这个方法会被调用,并接收事件传递的payload
数据。这里的逻辑是弹出一个提示框,显示收到的事件数据。
3. 事件总线
在大型应用中,可以使用事件总线(Event Bus)来管理不同组件之间的事件通信:
// EventBus.js
import Vue from 'vue';
export const EventBus = new Vue();
<!-- 组件A -->
<template><button @click="sendEvent">发送事件</button>
</template><script>
import { EventBus } from './EventBus';export default {methods: {sendEvent() {EventBus.$emit('custom-event', 'Hello from Component A');}}
}
</script>
<!-- 组件B -->
<template><div>接收到事件:{{ message }}</div>
</template><script>
import { EventBus } from './EventBus';export default {data() {return {message: ''}},created() {EventBus.$on('custom-event', (payload) => {this.message = payload;});}
}
</script>
在这个示例中,组件 A 通过事件总线发送事件,组件 B 接收并处理该事件,实现了组件之间的通信。
五、v-on
指令的注意事项
1. 事件解绑
在组件销毁时需要解绑事件监听器,以防止内存泄漏。Vue.js 会自动处理通过模板绑定的事件,但对于手动绑定的事件,需要手动解绑:
<template><div @click="handleClick">点击我</div>
</template><script>
export default {methods: {handleClick() {console.log('Clicked');}},beforeDestroy() {this.$off('custom-event', this.handleClick);}
}
</script>
2. 事件命名
在自定义事件命名时,尽量使用连字符(-
)而不是驼峰命名,以保持一致性和可读性:
<child-component @custom-event="handleEvent"></child-component>
相关文章:

【Vue】`v-on` 指令详解:事件绑定与处理的全面指南
文章目录 一、v-on 指令概述缩写语法 二、v-on 的基本用法1. 绑定方法2. 内联处理器 三、v-on 指令的高级用法1. 事件修饰符.stop.prevent.capture.self.once 2. 按键修饰符.enter自定义按键修饰符 3. 系统修饰符 四、v-on 指令的实际应用1. 表单处理模板部分 (<template>…...

【Spark On Hive】—— 基于电商数据分析的项目实战
文章目录 Spark On Hive 详解一、项目配置1. 创建工程2. 配置文件3. 工程目录 二、代码实现2.1 Class SparkFactory2.2 Object SparkFactory Spark On Hive 详解 本文基于Spark重构基于Hive的电商数据分析的项目需求,在重构的同时对Spark On Hive的全流程进行详细的…...

哪种SSL证书可以快速签发保护http安全访问?
用户访问网站,经常会遇到访问http网页时,提示网站不安全或者不是私密连接的提示,因为http是使用明文传输,数据传输中可能被篡改,数据不被保护,通常需要SSL证书来给数据加密。 SSL证书的签发速度࿰…...

深入探究理解大型语言模型参数和内存需求
概述 大型语言模型 取得了显著进步。GPT-4、谷歌的 Gemini 和 Claude 3 等模型在功能和应用方面树立了新标准。这些模型不仅增强了文本生成和翻译,还在多模态处理方面开辟了新天地,将文本、图像、音频和视频输入结合起来,提供更全面的 AI 解…...

maven 私服搭建(tar+docker)
maven私服搭建 一、linux安装nexus1、工具下载 二、 docker 搭建nexus1、镜像下载创建目录2、运行nexus3、访问确认,修改默认密码,禁用匿名用户登录4、创建仓库5、创建hostd仓库6、创建Blob Stores7、创建docker私服1、创建proxy仓库2、创建hotsed本地仓…...

银行业务知识全篇(财务知识、金融业务知识)
第一部分 零售业务 1.1 储蓄业务 4 1.1.1 普通活期储蓄(本外币) 4 1.1.2 定期储蓄(本外币) 5 1.1.3 活期一本通 9 1.1.4 定期一本通 10 1.1.5 电话银行 11 1.1.6 个人支票 11 1.1.7 通信存款 13 1.1.8 其他业务规…...
解决ElasticJob项目重启ZooKeeper注册冲突以及zkCli删除目录
解决ElasticJob项目重启ZooKeeper注册冲突以及zkCli删除目录 背景 在现代化的分布式调度系统中,ElasticJob 是一个非常流行的选择。它利用 ZooKeeper 作为注册中心来管理任务分片。然而,有时在项目重启时,会遇到 ZooKeeper 注册冲突的问题&…...

【EI检索】第二届机器视觉、图像处理与影像技术国际会议(MVIPIT 2024)
一、会议信息 大会官网:www.mvipit.org 官方邮箱:mvipit163.com 会议出版:IEEE CPS 出版 会议检索:EI & Scopus 检索 会议地点:河北张家口 会议时间:2024 年 9 月 13 日-9 月 15 日 二、征稿主题…...

vscode通过ssh链接远程服务器上的docker
目录 1 编译docker image1.1 编译镜像1.2 启动镜像 2 在docker container中启动ssh服务2.1 确认是否安装ssh server2.2 修改配置文件2.3 启动ssh服务 3 生成ssh key4 添加ssh公钥到docker container中5 vscode安装插件Remote - SSH6 在vscode中配置 1 编译docker image 一般来…...

使用NIFI连接瀚高数据库_并从RestFul的HTTP接口中获取数据局_同步到瀚高数据库中---大数据之Nifi工作笔记0067
首先来看一下如何,使用NIFI 去连接瀚高数据库. 其实,只要配置好了链接的,连接字符串,和驱动,任何支持JDBC的数据库都可以连接的. 首先我们用一个ListDatabaseTables处理器,来连接瀚高DB 主要是看这里,连接地址,以及驱动,还有驱动的位置 这个是数据连接的配置 jdbc:highgo://…...

IDEA的工程与模块管理
《IDEA破解、配置、使用技巧与实战教程》系列文章目录 第一章 IDEA破解与HelloWorld的实战编写 第二章 IDEA的详细设置 第三章 IDEA的工程与模块管理 第四章 IDEA的常见代码模板的使用 第五章 IDEA中常用的快捷键 第六章 IDEA的断点调试(Debug) 第七章 …...
[M前缀和] lc3096. 得到更多分数的最少关卡数目(前缀和+思维)
文章目录 1. 题目来源2. 题目解析 1. 题目来源 链接:3096. 得到更多分数的最少关卡数目 2. 题目解析 比较有意思的题目,仔细读题后发现解题没啥难度,但是如何写好、写的更简洁需要注意下: 思路: 数据量 1e5&#…...

基础vrrp(虚拟路由冗余协议)
一、VRRP 虚拟路由冗余协议 比如交换机上联两个路由器,由两个路由虚拟出一台设备设置终端设备的网关地址,两台物理路由的关系是主从关系,可以设置自动抢占。终端设备的网关是虚拟设备的ip地址,这样,如果有一台路由设备…...

《绝区零》是一款什么类型的游戏,Mac电脑怎么玩《绝区零》苹果电脑玩游戏怎么样
米哈游的《绝区零》最近在网上爆火呀,不过很多人都想知道mac电脑能不能玩《绝区零》,今天麦麦就给大家介绍一下《绝区零》是一款什么样的游戏,Mac电脑怎么玩《绝区零》。 一、《绝区零》是一款什么样的游戏 《绝区零》是由上海米哈游自主研发…...

Mysql sql技巧与优化
1、解决mysql同时更新、查询问题 2、控制查询优化 hint 3、 优化 特定类型的查 优化 COUNT() 查询 使用 近似值 业务能接受近似值的话,使用explain拿到近似值 优化关联查询 优化子查询 4、优化group by和distinct 优化GROUP BY WITH ROLLUP 5、优化 limit分页 其他…...

7.SpringBoot整合Neo4j
1.引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-neo4j</artifactId> </dependency> 说明:这里引入neo4j的版本跟spring框架的版本有关系。需要注意不同的版本在neo…...

教室管理系统的开发与实现(Java+MySQL)
引言 教室管理系统是学校和培训机构日常运营中不可或缺的工具。本文将介绍如何使用Java、Swing GUI、MySQL和JDBC开发一个简单而有效的教室管理系统,并涵盖系统的登录认证、教室管理、查询、启用、暂停和排课管理功能。 技术栈介绍 Java:作为主要编程…...
Go的入门
一、GO简介 Go语言(也叫 Golang)是Google开发的开源编程语言。 1. 语言特性 Go 语法简洁,上手容易,快速编译,支持跨平台开发,自动垃圾回收机制,天生的并发特性,更好地利用大量的分…...

windows中使用Jenkins打包,部署vue项目完整操作流程
文章目录 1. 下载和安装2. 使用1. 准备一个 新创建 或者 已有的 Vue项目2. git仓库3. 添加Jenkinsfile文件4. 成功示例 1. 下载和安装 网上有许多安装教程,简单罗列几个 Windows系统下Jenkins安装、配置和使用windows安装jenkins 2. 使用 在Jenkins已经安装的基础上,可以开始下…...
RocketMQ中概念知识点记录 和 与SpringBoot集成实现发送 同步、异步、延时、批量、tag、key、事务消息等
1. 消息模型 消息(Message): 是 RocketMQ 中数据传输的基本单位,由主题、标签、键值、消息体等组成。主题(Topic): 消息的分类,类似于邮件的主题,用于对消息进行粗粒度的分类。标签(…...

微软PowerBI考试 PL300-选择 Power BI 模型框架【附练习数据】
微软PowerBI考试 PL300-选择 Power BI 模型框架 20 多年来,Microsoft 持续对企业商业智能 (BI) 进行大量投资。 Azure Analysis Services (AAS) 和 SQL Server Analysis Services (SSAS) 基于无数企业使用的成熟的 BI 数据建模技术。 同样的技术也是 Power BI 数据…...

蓝牙 BLE 扫描面试题大全(2):进阶面试题与实战演练
前文覆盖了 BLE 扫描的基础概念与经典问题蓝牙 BLE 扫描面试题大全(1):从基础到实战的深度解析-CSDN博客,但实际面试中,企业更关注候选人对复杂场景的应对能力(如多设备并发扫描、低功耗与高发现率的平衡)和前沿技术的…...

Cinnamon修改面板小工具图标
Cinnamon开始菜单-CSDN博客 设置模块都是做好的,比GNOME简单得多! 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...
大模型多显卡多服务器并行计算方法与实践指南
一、分布式训练概述 大规模语言模型的训练通常需要分布式计算技术,以解决单机资源不足的问题。分布式训练主要分为两种模式: 数据并行:将数据分片到不同设备,每个设备拥有完整的模型副本 模型并行:将模型分割到不同设备,每个设备处理部分模型计算 现代大模型训练通常结合…...
什么?连接服务器也能可视化显示界面?:基于X11 Forwarding + CentOS + MobaXterm实战指南
文章目录 什么是X11?环境准备实战步骤1️⃣ 服务器端配置(CentOS)2️⃣ 客户端配置(MobaXterm)3️⃣ 验证X11 Forwarding4️⃣ 运行自定义GUI程序(Python示例)5️⃣ 成功效果 线程安全是指在多线程环境下,某个函数、类或代码片段能够被多个线程同时调用时,仍能保证数据的一致性和逻辑的正确性…...
管理学院权限管理系统开发总结
文章目录 🎓 管理学院权限管理系统开发总结 - 现代化Web应用实践之路📝 项目概述🏗️ 技术架构设计后端技术栈前端技术栈 💡 核心功能特性1. 用户管理模块2. 权限管理系统3. 统计报表功能4. 用户体验优化 🗄️ 数据库设…...

Kafka入门-生产者
生产者 生产者发送流程: 延迟时间为0ms时,也就意味着每当有数据就会直接发送 异步发送API 异步发送和同步发送的不同在于:异步发送不需要等待结果,同步发送必须等待结果才能进行下一步发送。 普通异步发送 首先导入所需的k…...
MySQL JOIN 表过多的优化思路
当 MySQL 查询涉及大量表 JOIN 时,性能会显著下降。以下是优化思路和简易实现方法: 一、核心优化思路 减少 JOIN 数量 数据冗余:添加必要的冗余字段(如订单表直接存储用户名)合并表:将频繁关联的小表合并成…...

Linux nano命令的基本使用
参考资料 GNU nanoを使いこなすnano基础 目录 一. 简介二. 文件打开2.1 普通方式打开文件2.2 只读方式打开文件 三. 文件查看3.1 打开文件时,显示行号3.2 翻页查看 四. 文件编辑4.1 Ctrl K 复制 和 Ctrl U 粘贴4.2 Alt/Esc U 撤回 五. 文件保存与退出5.1 Ctrl …...