vue事件绑定

简介: vue事件绑定



Vue提供了v-on指令来监听DOM事件,在事件绑定上,类似原生JavaScript的onclick事件写法,也是在HTML上进行监听。

基本用法

Vue中的事件绑定,使用v-on:事件名=函数名来完成,这里函数名定义在Vue实例的methods对象中,Vue实例可以直接访问其中的方法。

语法规则:

v-on:事件名.修饰符 = 方法名()|方法名|简单的JS表达式
简写:@事件名.修饰符 = 方法名()|方法名|简单的JS表达式
事件名:click|keydown|keyup|mouseover|mouseout|自定义事件名

1.直接使用

直接在标签中书写js方法,代码如下:注意:@click等同于v-on:click,是一个语法糖。

2.调用methods的方法

通过v-on绑定实例选项属性methods中的方法作为事件的处理器

单击button按钮,即可触发say函数,弹出alert框’Say Hello’。

(1)方法传参,方法直接在调用时在方法内传入参数,代码如下:

(2)传入事件对象,代码如下:

修饰符

Vue为指令v-on提供了多个修饰符,方便我们处理一些DOM事件的细节,Vue主要的修饰符如下。

(1).top:阻止事件继续传播,即阻止它的捕获和冒泡过程。代码如下:

@click.stop='handle()'  //只要在事件后面加上.stop就可以阻止事件冒泡

如例所示单击“内部单击”按钮,阻止了冒泡过程,即只执行inner这个方法,如果不加.stop,则先执行inner方法,然后执行outer方法,即通过了冒泡这个过程。

(2).prevent:阻止默认事件。代码如下:

@click.prevent='handle()'  //只要在事件后面加上.prevent就可以阻止默认事件

如下阻止了a标签的默认刷新:

(3).capture:添加事件监听器时使用事件捕获模式,即在捕获模式下触发。代码如下:

@click.capture='handle()'

如下实例在单击最里层的“单击6”时,outer方法先执行,因为outer方法在捕获模式执行,先于冒泡事件。按下列执行顺序执行:outer→set→inner,因为后两个还是冒泡模式下触发的事件,代码如下:

(4).self:当前元素自身是触发处理函数时才会触发函数。

原理是根据event.target确定是否为当前元素本身,以此来决定是否触发事件/函数。

如下示例,如果单击“内部单击”按钮,冒泡不会执行outer方法,因为event.target指的是内部单击的DOM元素,而不是外部单击的,所以不会触发自己的单击事件,代码如下:

(5).once:只触发一次。代码如下:

(2).prevent:阻止默认事件。代码如下:

@click.prevent='handle()'  //只要在事件后面加上.prevent就可以阻止默认事件

如下阻止了a标签的默认刷新:

(3).capture:添加事件监听器时使用事件捕获模式,即在捕获模式下触发。代码如下:

@click.capture='handle()'

如下实例在单击最里层的“单击6”时,outer方法先执行,因为outer方法在捕获模式执行,先于冒泡事件。按下列执行顺序执行:outer→set→inner,因为后两个还是冒泡模式下触发的事件,代码如下:

(4).self:当前元素自身是触发处理函数时才会触发函数。

原理是根据event.target确定是否为当前元素本身,以此来决定是否触发事件/函数。

如下示例,如果单击“内部单击”按钮,冒泡不会执行outer方法,因为event.target指的是内部单击的DOM元素,而不是外部单击的,所以不会触发自己的单击事件,代码如下:

(5).once:只触发一次。代码如下:

(6)键盘事件。

方式一:@keydown=‘show($event)’

目录
相关文章
|
5天前
|
JavaScript
vue消息订阅与发布
vue消息订阅与发布
|
2天前
|
JavaScript
理解 Vue 的 setup 应用程序钩子
【10月更文挑战第3天】`setup` 函数是 Vue 3 中的新组件选项,在组件创建前调用,作为初始化逻辑的入口。它接收 `props` 和 `context` 两个参数,内部定义的变量和函数需通过 `return` 暴露给模板。`props` 包含父组件传入的属性,`context` 包含组件上下文信息。`setup` 可替代 `beforeCreate` 和 `created` 钩子,并提供类似 `data`、`computed` 和 `methods` 的功能,支持逻辑复用和 TypeScript 类型定义。
20 11
|
6天前
|
JavaScript 前端开发 IDE
Vue学习笔记5:用Vue的事件监听 实现数据更新的实时视图显示
Vue学习笔记5:用Vue的事件监听 实现数据更新的实时视图显示
|
6天前
|
JavaScript 前端开发 API
Vue学习笔记4:用reactive() 实现数据更新的实时视图显示
Vue学习笔记4:用reactive() 实现数据更新的实时视图显示
|
4天前
|
JavaScript
vue尚品汇商城项目-day07【vue插件-50.(了解)表单校验插件】
vue尚品汇商城项目-day07【vue插件-50.(了解)表单校验插件】
13 4
|
4天前
|
JavaScript
vue尚品汇商城项目-day07【51.路由懒加载】
vue尚品汇商城项目-day07【51.路由懒加载】
15 4
|
5天前
|
JavaScript 前端开发
Vue学习笔记8:解决Vue学习笔记7中用v-for指令渲染列表遇到两个问题
Vue学习笔记8:解决Vue学习笔记7中用v-for指令渲染列表遇到两个问题
|
4天前
|
JavaScript
vue尚品汇商城项目-day07【vue插件-54.(了解)生成二维码插件】
vue尚品汇商城项目-day07【vue插件-54.(了解)生成二维码插件】
14 2
|
5天前
|
JavaScript 前端开发 API
Vue学习笔记7:使用v-for指令渲染列表
Vue学习笔记7:使用v-for指令渲染列表
|
6天前
|
JavaScript
vue 函数化组件
vue 函数化组件
下一篇
无影云桌面