码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 常见Vue事件修饰符浅析


    一、.stop修饰符

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

    
    <a @click.stop="doThis">a>
    
    • 1
    • 2

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

    
    doThis(event){
    event.stoppropagation()
    }
    
    • 1
    • 2
    • 3
    • 4

    二、.prevent修饰符(重要)

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

    
    <form @submit.prevent="onSubmit">form>
    
    • 1
    • 2

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

    onSubmit(event){
    event.preventDefault()
    }
    
    • 1
    • 2
    • 3

    三、.capture修饰符

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

    element.addEventListener(<event-name>,<callback>,{
    capture:false,
    passive:false,
    once:false
    });
    
    • 1
    • 2
    • 3
    • 4
    • 5

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

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

    相当于

    <div ref="div">div>
    const app=new Vue({
    el:'#app',
    mounted(){
           this.$refs.div.addEventListener('click',doThis,{capture:ture})
    }
    })
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    四、.passive修饰符

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

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

    等于

    <div ref="div">...div>
    const app=new Vue({
    el:'app',
    mounted(){
    this.$refs.div.addEventListener('scroll',onScroll,{passive:true})
    }
    })
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
  • 相关阅读:
    【ECharts】仪表盘指针自定义形状
    LLM 大模型学习必知必会系列(十二):VLLM性能飞跃部署实践:从推理加速到高效部署的全方位优化[更多内容:XInference/FastChat等框架]
    数据结构_排序总结
    spark性能优化调优指导性文件
    JAVA计算机毕业设计程序设计类课程的课堂教学效果评价系统Mybatis+系统+数据库+调试部署
    Redis系列:Redis主从、哨兵、集群介绍
    pnpm 是凭什么对 npm 和 yarn 降维打击的
    【SwiftUI模块】0021、SwiftUI做一个基于拖动手势位置的精美扩展工具栏
    Github或Gitlab等申请PR或MR(pull request & merge request)的时候如果不能自动合并代码发生冲突了要怎么办
    ROS(0)命令及学习资源汇总
  • 原文地址:https://blog.csdn.net/m0_67587248/article/details/133713904
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号