Vue中如何使用事件修饰符

发布时间:2021-07-21 11:19:59 作者:Leah
来源:亿速云 阅读:170

Vue中如何使用事件修饰符,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

        一、 DOM 事件流
        有时,当我们需要完成页面中的某些功能时,我们要在需要实现功能的页面元素上使用 v-on 指令去监听 DOM 事件,在 html4 时代浏览器如何确定页面的哪一部分会拥有特定的事件时,IE 和 Netscape 的开发团队提出了两个截然相反的概念。这一差异,也使我们在写代码中需要考虑如何去处理 DOM 的事件细节。为了解决这一问题,vue 给我们提供了事件修饰符这一利器,它使我们的方法只有纯粹的数据逻辑,而不是去处理 DOM 事件细节。
        一些涉及到概念:
        1、事件:用户设定或者是浏览器自身执行的某种动作。例如click(点击)、load(加载)、mouseover(鼠标悬停)、change(改变)等等
        2、事件处理程序:为了实现某个事件的功能而构建的函数方法,也可称为事件监听器
        3、DOM 事件流:描述的是从页面中接收事件的顺序,也可理解为事件在页面中传播的顺序

        在 DOM 事件流中存在着三个阶段:事件捕获阶段、处于目标阶段、事件冒泡阶段
        事件捕获(event capture):当鼠标点击或者触发 DOM 事件时,浏览器会从根节点开始由外到内进行事件传播,即点击了子元素,如果父元素通过事件捕获方式注册了对应的事件的话,会先触发父元素绑定的事件
        事件冒泡(event bubbing):当鼠标点击或者触发 DOM 事件时,浏览器会从根节点开始由内到外进行事件传播,即点击了子元素,则先触发子元素绑定的事件,逐步扩散到父元素绑定的事件
        之前我们提到的 IE 和 Netscape 的开发团队提出了两个截然相反的事件流概念,IE 采取的是事件冒泡流,而标准的浏览器的事件流则是事件捕获流。所以,为了兼容 IE 我们需要改变某些的写法。

        二、 事件修饰符
        1、.stop:阻止事件冒泡
        在下面的示例中,我们分别创建了一个 button 的点击事件和外侧的 div 的点击事件,根据事件的冒泡机制我们可以得知,当我们点击了按钮之后,会扩散到父元素,从而触发父元素的点击事件,具体的结果也如下图所示:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<div id="app" class="divDefault">
   <div id="div1" @click="divHandlerClick">
       <input type="button" value="点击" @click="btnHandlerClick" />
   </div>
</div>

<script>
   var vm = new Vue({
       el: '#app',
       data: {},
       methods: {
           divHandlerClick() {
               alert('我是div的点击事件!')
           },
           btnHandlerClick() {
               alert('我是button的点击事件')
           }
       }
   });
</script>

        这时候,如果我们不希望出现事件冒泡,则可以使用 Vue 内置的修饰符便捷的阻止事件冒泡的产生。因为我们是点击 button 后产生的事件冒泡,我们只需要在 button 的点击事件上加上 stop 修饰符即可,示例代码如下。

1
<input type="button" value="点击" @click.stop="btnHandlerClick" />

        2、.prevent:阻止默认事件
        阻止默认事件这个也很好理解,有些标签本身会存在事件,例如,a 标签的跳转,form 表单中 submit 按钮的提交事件等等,在某些时候我们只想执行我们自己设置的事件,这时,就需要阻止标签的默认事件的执行,原生的 js 我们可以使用 preventDefault 方法来实现,而在 Vue 中,我们只需要使用 prevent 关键字就可以了。
        在下面的示例中,我们为 a 标签添加了一个点击事件,由于 a 标签本身具有默认的跳转事件,此时,当我们点击后,最终还是会执行 a 标签的默认事件。

1
2
3
4
5
6
7
8
9
10
11
12
13
<a href="http://www.baidu.com" @click="aHandlerClick">链接跳转</a>

<script>
var vm = new Vue({
       el: '#app',
       data: {},
       methods: {
           aHandlerClick() {
    alert('我是a标签的点击事件')
}
       }
   });
</script>

        在 Vue 中,当我们想要阻止元素的默认事件,只需要在绑定的事件后使用 prevent 修饰符即可,示例代码如下。

1
<a href="http://www.baidu.com" @click.prevent="aHandlerClick">链接跳转</a>

        3、.capture:添加事件监听器时使用事件捕获模式
        在上面的学习中我们了解到,事件捕获模式与事件冒泡模式是一对相反的事件处理流程,当我们想要将页面元素的事件流改为事件捕获模式时,只需要在父级元素的事件上使用 capture 修饰符即可,还是上面的例子的代码,当我们在 div 绑定的点击事件上使用 capture 修饰符后,我们点击按钮首先触发的就是最外侧的 div 的事件。

1
2
3
4
5
<div id="app" class="divDefault">
   <div id="div1" @click.capure="divHandlerClick">
       <input type="button" value="点击" @click="btnHandlerClick" />
   </div>
</div>

        4、.self:只当在 event.target 是当前元素自身时触发处理函数(比如不是子元素冒泡引起的事件触发)
        在上面的例子中,我们为 div 绑定了一个点击事件,而我们的本意可能是只有当我们点击 div 后触发这个事件,而实际情况是事件冒泡还是事件捕获都会触发这个事件,这与我们的本意是不符的。在 Vue 中,我们就可以使用 self 修饰符去修饰事件,让这个事件只在我们想要触发时触发。

1
2
3
4
5
<div id="app" class="divDefault">
   <div id="div1" @click.self="divHandlerClick">
       <input type="button" value="点击" @click="btnHandlerClick" />
   </div>
</div>

        5、.once:事件只触发一次
        当我们仅仅想对绑定的事件只在第一次的时候触发,这时我们就可以使用 once 修饰符去修饰绑定的事件。例如在下面的代码中,只有第一次点击时才会触发绑定的事件,之后点击都不会触发。

1
<input type="button" value="点击" @click.once="btnHandlerClick" />

        6、.passive:滚动事件的默认行为 (即滚动行为) 将会立即触发
        在页面滚动的时候,浏览器会在整个事件处理完毕之后再触发滚动,因为浏览器并不知道这个事件是否在其处理函数中被调用了 event.preventDefault(),而 passive 修饰符用来进一步告诉浏览器这个事件的默认行为不会被取消,即 使用 passive 修饰符后表示绑定的事件永远不会调用 event.preventDefault()。

总结

        1、使用修饰符时,顺序很重要;相应的代码会以同样的顺序产生。因此,用 v-on:click.prevent.self 会阻止所有的点击,而 v-on:click.self.prevent 只会阻止对元素自身的点击。
        2、不要把 .passive 和 .prevent 一起使用,因为 .prevent 将会被忽略,同时浏览器可能会向你展示一个警告。请记住,.passive 会告诉浏览器你不想阻止事件的默认行为。

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

推荐阅读:
  1. 用事件修饰符来修改事件
  2. Vue事件修饰符native、self示例详解

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue

上一篇:java的反射技术详细介绍

下一篇:如何解决vue中修改export default中脚本报一大堆错的问题

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》