【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): 消息的分类,类似于邮件的主题,用于对消息进行粗粒度的分类。标签(…...
Chapter03-Authentication vulnerabilities
文章目录 1. 身份验证简介1.1 What is authentication1.2 difference between authentication and authorization1.3 身份验证机制失效的原因1.4 身份验证机制失效的影响 2. 基于登录功能的漏洞2.1 密码爆破2.2 用户名枚举2.3 有缺陷的暴力破解防护2.3.1 如果用户登录尝试失败次…...
在软件开发中正确使用MySQL日期时间类型的深度解析
在日常软件开发场景中,时间信息的存储是底层且核心的需求。从金融交易的精确记账时间、用户操作的行为日志,到供应链系统的物流节点时间戳,时间数据的准确性直接决定业务逻辑的可靠性。MySQL作为主流关系型数据库,其日期时间类型的…...
JavaScript 中的 ES|QL:利用 Apache Arrow 工具
作者:来自 Elastic Jeffrey Rengifo 学习如何将 ES|QL 与 JavaScript 的 Apache Arrow 客户端工具一起使用。 想获得 Elastic 认证吗?了解下一期 Elasticsearch Engineer 培训的时间吧! Elasticsearch 拥有众多新功能,助你为自己…...
JVM垃圾回收机制全解析
Java虚拟机(JVM)中的垃圾收集器(Garbage Collector,简称GC)是用于自动管理内存的机制。它负责识别和清除不再被程序使用的对象,从而释放内存空间,避免内存泄漏和内存溢出等问题。垃圾收集器在Ja…...
Linux-07 ubuntu 的 chrome 启动不了
文章目录 问题原因解决步骤一、卸载旧版chrome二、重新安装chorme三、启动不了,报错如下四、启动不了,解决如下 总结 问题原因 在应用中可以看到chrome,但是打不开(说明:原来的ubuntu系统出问题了,这个是备用的硬盘&a…...
土地利用/土地覆盖遥感解译与基于CLUE模型未来变化情景预测;从基础到高级,涵盖ArcGIS数据处理、ENVI遥感解译与CLUE模型情景模拟等
🔍 土地利用/土地覆盖数据是生态、环境和气象等诸多领域模型的关键输入参数。通过遥感影像解译技术,可以精准获取历史或当前任何一个区域的土地利用/土地覆盖情况。这些数据不仅能够用于评估区域生态环境的变化趋势,还能有效评价重大生态工程…...
【服务器压力测试】本地PC电脑作为服务器运行时出现卡顿和资源紧张(Windows/Linux)
要让本地PC电脑作为服务器运行时出现卡顿和资源紧张的情况,可以通过以下几种方式模拟或触发: 1. 增加CPU负载 运行大量计算密集型任务,例如: 使用多线程循环执行复杂计算(如数学运算、加密解密等)。运行图…...
【python异步多线程】异步多线程爬虫代码示例
claude生成的python多线程、异步代码示例,模拟20个网页的爬取,每个网页假设要0.5-2秒完成。 代码 Python多线程爬虫教程 核心概念 多线程:允许程序同时执行多个任务,提高IO密集型任务(如网络请求)的效率…...
k8s业务程序联调工具-KtConnect
概述 原理 工具作用是建立了一个从本地到集群的单向VPN,根据VPN原理,打通两个内网必然需要借助一个公共中继节点,ktconnect工具巧妙的利用k8s原生的portforward能力,简化了建立连接的过程,apiserver间接起到了中继节…...
jmeter聚合报告中参数详解
sample、average、min、max、90%line、95%line,99%line、Error错误率、吞吐量Thoughput、KB/sec每秒传输的数据量 sample(样本数) 表示测试中发送的请求数量,即测试执行了多少次请求。 单位,以个或者次数表示。 示例:…...
