当前位置: 首页 > news >正文

常见Vue事件修饰符浅析

一、.stop修饰符

.stop修饰符代表event.stopPropagation(),加上这个修饰符,就等于在方法中加上了这句代码。

<!--阻止单击事件继续传播-->
<a @click.stop="doThis"></a>

上面的代码等同于如下代码。

<!--阻止单击事件继续传播-->
doThis(event){
event.stoppropagation()
}

二、.prevent修饰符(重要)

.prevent修饰符代表event.preventDefault(),加上这个修饰符,就等于在方法中加上了这句代码。例如提交submit事件后触发自动刷新页面,但是加了这个修饰符之后就不会再触发。

<!--提交事件不再重载页面-->
<form @submit.prevent="onSubmit"></form>

上述代码等同于如下代码。

onSubmit(event){
event.preventDefault()
}

三、.capture修饰符

在事件监听器中通常有3个参数:监听的事件名称、回调函数和是否设置capture。所谓的capture就是指在事件捕获阶段监听还是在冒泡阶段监听,将其设置为true表示在捕获阶段监听,设置为false表示在冒泡阶段监听。

element.addEventListener(<event-name>,<callback>,{
capture:false,
passive:false,
once:false
});

设置.capture修饰符就代表在捕获阶段监听,不设置该修饰符则代表在冒泡阶段监听。所谓捕获阶段是指先执行点击元素自身的事件,再从外到里依次执行元素内部的事件。而冒泡阶段是先执行内部元素的事件,再由里到外执行父级元素的事件。

<div v-on:click.capture="doThis">...</div>

相当于

<div ref="div"></div>
const app=new Vue({
el:'#app',
mounted(){this.$refs.div.addEventListener('click',doThis,{capture:ture})
}
})

四、.passive修饰符

通常在监听时间的时候,只有当监听事件的方法执行完成后才会执行默认的操作。例如执行滚动操作,当监听页面的滚动事件时,只有当方法执行过程结束后页面才会滚动,但当在移动端时就会造成滚动卡顿的现象。
添加.passive修饰符,等于告诉浏览器不需要等到方法执行完成后再去触发滚动事件,而是立刻触发。这样可以提升移动端性能,为用户带来流畅的操作体验,因此.passive修饰符在移动端的使用比较常见。

<div v-on:scroll.passive="onScroll">...</div>

等于

<div ref="div">...</div>
const app=new Vue({
el:'app',
mounted(){
this.$refs.div.addEventListener('scroll',onScroll,{passive:true})
}
})
http://www.lryc.cn/news/187460.html

相关文章:

  • 怎样开始用selenium进行自动化测试?
  • 二维数组多次排序 或 嵌套list多次排序
  • Flutter - 波浪动画和lottie动画的使用
  • 忘记压缩包密码?解决方法一键找回,省时又便捷!
  • “UTONMOS”掀起元宇宙游戏热潮,全球发展前景广阔
  • 用idea工具scala 和 Java开发 spark案例:WordCount
  • 【git merge/rebase】详解合并代码、解决冲突
  • nrm,npm源的管理工具
  • HarmonyOS/OpenHarmony原生应用-ArkTS万能卡片组件Stack
  • 腾讯云2核4G服务器一年和三年价格性能测评
  • 集线器、交换机、路由器是如何转发包的
  • 交通物流模型 | MDRGCN:用于多模式交通客流预测的深度学习模型
  • 保研经历分享(一)
  • 【手写数字识别】数据挖掘实验二
  • 什么是云计算?云计算简介
  • Vue路由进阶--VueRouter声明式导航
  • Oracle 云服务即将支持 PostgreSQL!
  • 数字孪生项目:突破技术难关,引领未来发展
  • MySQL 如何使用离线模式维护服务器
  • 期权开户流程合集——期权开户的操作步骤
  • mysql改造oracle,以及项目改造
  • 利用互斥锁实现多个线程写一个文件
  • 【m98】视频缓存PacketBuffer 1 : SeqNumUnwrapper int64映射、ForwardDiff
  • day58:ARMday5,GPIO流水灯实验
  • Linux shell编程学习笔记9:字符串运算 和 if语句
  • 【分享】xpath的属性表达式
  • Oracle Dataguard跨版本数据迁移(11.2.0.4~19.13.0.0)
  • 零基础Linux_14(基础IO_文件)缓冲区+文件系统inode等
  • Vue中的router路由的介绍(快速入门)
  • ESP-07S进行TCP 通信测试