热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Vue3手册译稿事件处理

事件处理事件监听当DOM事件被触发时,我们使用v-on(缩写@符号)来监听事件,运行JavaScript。使用方法为v-on:clickmethod或缩写为@clickmet

事件处理

事件监听

当DOM事件被触发时,我们使用v-on(缩写@符号)来监听事件,运行Javascript。使用方法为v-on:click="method"或缩写为@click="method"

例如:



The button above has been clicked {{ counter }} times.



Vue.createApp({
data() {
return {
counter: 0
}
}
}).mount('#basic-event')

事件处理方法

因为有些事件处理比较复杂的逻辑,所以直接在v-on后面写Javascript是不太现实的。所以v-on可以接受一个方法名来调用。例如:





Vue.createApp({
data() {
return {
name: 'Vue.js'
}
},
methods: {
greet(event) {
// `this` inside methods points to the current active instance
alert('Hello ' + this.name + '!')
// `event` is the native DOM event
if (event) {
alert(event.target.tagName)
}
}
}
}).mount('#event-with-method')

事件方法传递参数

(感觉这个翻译靠谱点吧。原文是Methods in Inline Handlers)





Vue.createApp({
methods: {
say(message) {
alert(message)
}
}
}).mount('#inline-handler')

有时候我们需要在方法中访问DOM的原生事件句柄,你可以通过$event传递进来:


// ...
methods: {
warn(message, event) {
// now we have access to the native event
if (event) {
event.preventDefault()
}
alert(message)
}
}

多事件处理

你可以在一个事件中调用多个用逗号分隔的方法,如下:



// ...
methods: {
one(event) {
// 第一个事件的业务逻辑
},
two(event) {
// 第二个事件的业务逻辑
}
}

事件修饰符

事件响应过程中经常会用到event.preventDefault()event.stopPropagation()。虽然我们可以在方法里简单的调用,但最好方法完全是数据逻辑而不必去处理DOM细节。

针对这个问题,Vue提供了v-on的修饰符。调用方法是在指令后面加一个后缀。



  • .stop

  • .prevent

  • .capture

  • .self

  • .once

  • .passive





...

...


[info]提示

使用修饰符顺序问题同代码的书写顺序。因此使用@click.prevent.self会阻止所有点击而@click.sel.prevent只会阻止元素自身的点击。



.once不像其他修饰符只能用于原生组件,它也可以应用于组件。如果你还没有阅读过组件知识,先别烦神了。

Vue同时提供.passive修饰符,同addEventListenerpassive选项一样。


...

passive修饰符对移动端性能提升尤为有用。


[info]不要把.passive.prevent同时使用,因为prevent会被忽略且浏览器会收到警告信息。记住,.passive通知浏览器你不想阻止事件的默认行为。



键修饰符

我们经常需要监听键盘上特殊按键行为。Vue允许使用v-on@来监听键盘的输入:



你可以使用任意通过`keyboardEvent.key暴露出来的键名作为修饰符,只要使用驼峰命名即可。


PageDown按钮触发事件。


键别名

Vue提供了大部分常用键的别名



  • .enter

  • .tab

  • .delete(同时捕获 "Delete" 和 "Backspace" 键)

  • .esc

  • .space

  • .up

  • .down

  • .left

  • .right


系统控制键修饰符

当相应的修饰键被按下时,你可以使用以下修饰键触发鼠标或键盘事件监听:



  • .ctrl

  • .alt

  • .shift

  • .meta


[info]mac电脑meta指的是命令键(⌘),Windows电脑指的是windows键(⊞)。在sun公司的微系统键盘,meta指的是实心菱形键(◆)。在其他特定键盘上,尤其在 MIT 和 Lisp 机器的键盘、以及其后继产品,比如 Knight 键盘、space-cadet 键盘,meta 被标记为“META”。在符号键盘上,meta 被标记为“META”或者“Meta”。


示例:



Do something


[warning] 系统控制键修饰在使用key.up时不同于普通键,它在按下时指令就发出了。换句话说,只有按下ctrl释放其它键时才会触发事件,单单释放ctrl键并不会触发事件。



.exact修饰符

exact修饰符控制系统组合键触发事件:






鼠标修饰符



  • .left

  • .right

  • .middle

    鼠标按钮修饰符会阻事件只响应鼠标特定按钮点击。


为什么在HTML中监听?

你可能注意到了所有一的事件监听貌似违反了“关键点隔离”这个好的旧规则。请放宽心,因为所有Vue的操作函数及表达式均已绑定到当前视图的ViewModel,维护起来一点也不困难。事实上使用v-on@还有一些优点。



  1. 通过浏览HTML模板很容易定位到操作函数的JS实现代码。

  2. 因为你不需要再在JS代码里人工设置监听,你的ViewModel代码只需要关注纯逻辑和DOM。这也更容易进行测试。

  3. 当一个ViewModel被销毁,所有的事件监听也会移除。不需要再手工清除。



推荐阅读
  • ButterKnife 是一款用于 Android 开发的注解库,主要用于简化视图和事件绑定。本文详细介绍了 ButterKnife 的基础用法,包括如何通过注解实现字段和方法的绑定,以及在实际项目中的应用示例。此外,文章还提到了截至 2016 年 4 月 29 日,ButterKnife 的最新版本为 8.0.1,为开发者提供了最新的功能和性能优化。 ... [详细]
  • 如果应用程序经常播放密集、急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了。因为MediaPlayer存在如下缺点:1)延时时间较长,且资源占用率高 ... [详细]
  • 本文探讨了资源访问的学习路径与方法,旨在帮助学习者更高效地获取和利用各类资源。通过分析不同资源的特点和应用场景,提出了多种实用的学习策略和技术手段,为学习者提供了系统的指导和建议。 ... [详细]
  • 在处理遗留数据库的映射时,反向工程是一个重要的初始步骤。由于实体模式已经在数据库系统中存在,Hibernate 提供了自动化工具来简化这一过程,帮助开发人员快速生成持久化类和映射文件。通过反向工程,可以显著提高开发效率并减少手动配置的错误。此外,该工具还支持对现有数据库结构进行分析,自动生成符合 Hibernate 规范的配置文件,从而加速项目的启动和开发周期。 ... [详细]
  • 本文详细介绍了在 CentOS 7 系统中配置 fstab 文件以实现开机自动挂载 NFS 共享目录的方法,并解决了常见的配置失败问题。 ... [详细]
  • 微信公众号推送模板40036问题
    返回码错误码描述说明40001invalidcredential不合法的调用凭证40002invalidgrant_type不合法的grant_type40003invalidop ... [详细]
  • 本文介绍了如何利用Struts1框架构建一个简易的四则运算计算器。通过采用DispatchAction来处理不同类型的计算请求,并使用动态Form来优化开发流程,确保代码的简洁性和可维护性。同时,系统提供了用户友好的错误提示,以增强用户体验。 ... [详细]
  • 微信小程序实现类似微博的无限回复功能,内置云开发数据库支持
    本文详细介绍了如何利用微信小程序实现类似于微博的无限回复功能,并充分利用了微信云开发的数据库支持。文中不仅提供了关键代码片段,还包含了完整的页面代码,方便开发者按需使用。此外,HTML页面中包含了一些示例图片,开发者可以根据个人喜好进行替换。文章还将展示详细的数据库结构设计,帮助读者更好地理解和实现这一功能。 ... [详细]
  • 本文详细介绍了在 Vue.js 前端框架中集成 vue-i18n 插件以实现多语言支持的方法。通过具体的配置步骤和示例代码,帮助开发者快速掌握如何在项目中实现国际化功能,提升用户体验。同时,文章还探讨了常见的多语言切换问题及解决方案,为开发人员提供了实用的参考。 ... [详细]
  • 在 Vbox 和 Hbox 布局中,当用户点击容器添加一个矩形时,系统会自动为该矩形分配坐标并打印其位置信息。此外,在按键事件触发时,系统仅打印当前矩形的坐标值。这两种布局在特定的交互场景下,能够动态地管理和更新子组件的位置。 ... [详细]
  • feat: Enhances Jest Testing Capabilities with Snapshot Support ... [详细]
  • 在处理大规模数据数组时,优化分页组件对于提高页面加载速度和用户体验至关重要。本文探讨了如何通过高效的分页策略,减少数据渲染的负担,提升应用性能。具体方法包括懒加载、虚拟滚动和数据预取等技术,这些技术能够显著降低内存占用和提升响应速度。通过实际案例分析,展示了这些优化措施的有效性和可行性。 ... [详细]
  • 本文详细介绍了一种利用 ESP8266 01S 模块构建 Web 服务器的成功实践方案。通过具体的代码示例和详细的步骤说明,帮助读者快速掌握该模块的使用方法。在疫情期间,作者重新审视并研究了这一未被充分利用的模块,最终成功实现了 Web 服务器的功能。本文不仅提供了完整的代码实现,还涵盖了调试过程中遇到的常见问题及其解决方法,为初学者提供了宝贵的参考。 ... [详细]
  • 本指南详细介绍了在Linux环境中高效连接MySQL数据库的方法。用户可以通过安装并使用`mysql`客户端工具来实现本地连接,具体命令为:`mysql -u 用户名 -p 密码 -h 主机`。例如,使用管理员账户连接本地MySQL服务器的命令为:`mysql -u root -p pass`。此外,还提供了多种配置优化建议,以确保连接过程更加稳定和高效。 ... [详细]
  • 将JavaScript文件嵌入HTML文档是Web开发中的基本操作。常见的方法是通过在HTML文件中使用``标签来引用外部的.js文件。这种方法不仅保持了代码的整洁性,还便于管理和维护。此外,还可以利用模块化脚本和异步加载技术进一步提升页面性能。 ... [详细]
author-avatar
sddfdffwfefe_863
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有