Vue中v-on指令简单事件绑定的属性分析(附代码)
这篇文章给大家介绍的文章内容是关于Vue中v-on指令简单事件绑定的属性分析(附代码),有很好的参考价值,希望可以帮助到有需要的朋友。
前言
上一篇文章以v-on指令绑定click事件为例介绍了v-on指令的使用方法,本文介绍一下v-on绑定事件的一些属性的使用方法。
v-on绑定指令属性
.stop属性
阻止单击事件继续向上传播(简单点说就是不让父节点及父节点以上的节点事件触发),本示例如果没有stop属性,父节点和爷爷节点事件将会触发,并在控制台输出内容,示例代码和示例结果如下:
1 <template> 2 <div> 3 <p class="title1">{{title}}</p> 4 <div class="div1"> 5 <div v-on:click="clickme0"> 6 {{ msg1}} 7 <div v-on:click="clickme"> 8 {{msg2}}<br/> 9 <span v-on:click="clickthis">{{msg3}}</span> 10 </div> 11 </div> 12 </div> 13 </div> 14 15 </template> 16 17 <script> 18 export default { 19 name: 'v-on', 20 data() { 21 return { 22 msg1: '我是爷爷节点', 23 msg2: '我是父节点', 24 msg3: '测试click属性', 25 title: 'v-on指令学习' 26 } 27 }, 28 methods:{ 29 clickme0(){ 30 console.log("我是爷爷节点"); 31 }, 32 clickme(){ 33 console.log("我是父节点"); 34 }, 35 clickthis(){ 36 console.log("不打印父节点事件内容!") 37 } 38 } 39 } 40 </script> 41 42 <style scoped> 43 .title1 { 44 text-align: left; 45 } 46 .div1{ 47 float: left; 48 } 49 </style>
如果添加stop属性,则不会触发父节点和爷爷节点事件,不会在控制台输出相应事件内容,示例代码和示例结果如下:
1 <template> 2 <div> 3 <p class="title1">{{title}}</p> 4 <div class="div1"> 5 <div v-on:click="clickme0"> 6 {{ msg1}} 7 <div v-on:click="clickme"> 8 {{msg2}}<br/> 9 <span v-on:click.stop="clickthis">{{msg3}}</span> 10 </div> 11 </div> 12 </div> 13 </div> 14 15 </template> 16 17 <script> 18 export default { 19 name: 'v-on', 20 data() { 21 return { 22 msg1: '我是爷爷节点', 23 msg2: '我是父节点', 24 msg3: '测试click属性', 25 title: 'v-on指令学习' 26 } 27 }, 28 methods:{ 29 clickme0(){ 30 console.log("我是爷爷节点"); 31 }, 32 clickme(){ 33 console.log("我是父节点"); 34 }, 35 clickthis(){ 36 console.log("不打印父节点事件内容!") 37 } 38 } 39 } 40 </script> 41 42 <style scoped> 43 .title1 { 44 text-align: left; 45 } 46 .div1{ 47 float: left; 48 } 49 </style>
.prevent属性
该方法将通知 Web 浏览器不要执行与事件关联的默认动作(如果存在这样的动作),注意如果 Event 对象的 cancelable 属性是 fasle,那么就没有默认动作,或者不能阻止默认动作,无论哪种情况,调用该属性都没有作用。
简单示例如下,在页面from表单中 如果 type 属性是 "submit"
如果没有指定prevent,点击事件自动触发from表单action跳向指定的网站,示例代码和实例结果如下:
<template> <div> <p class="title1">{{title}}</p> <div class="div1"> <form action="http://www.baidu.com" v-on:submit="clickme"> <button type="submit">{{msg}}</button> </form> <!--<a href="http://www.baidu.com" v-on:click.prevent="banclickme">点我去百度</a>--> </div> </div> </template> <script> export default { name: 'v-on', data() { return { title: 'v-on指令学习', msg: 'form表单默认点击打开百度' } }, methods:{ clickme(){ console.log("页面重新加载了"); } // banclickme(){ // console.log("去不了百度吧") // } } } </script> <style scoped> .title1 { text-align: left; } .div1{ float: left; } </style>
如果指定prevent,点击事件则不会触发from表单action跳向指定的网站,示例代码和实例结果如下:
<template> <div> <p class="title1">{{title}}</p> <div class="div1"> <form action="http://www.baidu.com" v-on:submit.prevent="clickme"> <button type="submit">{{msg}}</button> </form> <!--<a href="http://www.baidu.com" v-on:click.prevent="banclickme">点我去百度</a>--> </div> </div> </template> <script> export default { name: 'v-on', data() { return { title: 'v-on指令学习', msg: 'form表单默认点击打开百度' } }, methods:{ clickme(){ console.log("去不了百度吧"); } // banclickme(){ // console.log("去不了百度吧") // } } } </script> <style scoped> .title1 { text-align: left; } .div1{ float: left; } </style>
.capture属性
添加事件监听器时使用事件捕获模式,即元素自身触发的事件先在此处处理,然后才交由内部元素进行处理,当点击最底层元素
触发事件时,先查找带有监听器的元素,按照节点优先级先触发带有该修饰符的元素,然后触发自身事件,最后发生事件冒泡。
本示例中先触发打印爷爷节点,然后触发打印父节点,然后打印自身节点,最后触发打印曾祖父节点,示例代码和结果如下:
<template> <div> <p class="title1">{{title}}</p> <div class="div1" v-on:click="click3"> {{msg3}}<br/> <div class="div1" v-on:click.capture="click2"> {{msg2}}<br/> <div class="div1" v-on:click.capture="click1"> {{msg1}}<br/> <div v-on:click="click0">{{msg}}</div> </div> </div> </div> </div> </template> <script> export default { name: 'v-on', data() { return { title: 'v-on指令学习', msg: '我是div内部子节点', msg1: '我是div父节点', msg2: '我是div爷爷节点', msg3: '我是div曾祖父节点' } }, methods:{ click0(){ console.log("打印子节点"); }, click1(){ console.log("打印父节点"); }, click2(){ console.log("打印爷爷节点"); }, click3(){ console.log("打印曾祖父节点"); } } } </script> <style scoped> .title1 { text-align: left; } .div1{ float: left; } </style>
.self属性
只当在event.target是当前元素自身时触发处理函数,即事件不是从内部元素触发的。通俗点说只有点击元素本身的时候触发事件,当点击父元素触发事件或者点击子元素发生事件冒泡时并不触发元素本身事件。
本示例点击父节点或者子节点时并不打印本身元素事件,示例代码和实例结果如下:
<template> <div> <p class="title1">{{title}}</p> <div class="div1" v-on:click="click3"> {{msg3}}<br/> <div class="div1" v-on:click.self="click2"> {{msg2}}<br/> <div class="div1" v-on:click="click1"> {{msg1}}<br/> <div v-on:click="click0">{{msg}}</div> </div> </div> </div> </div> </template> <script> export default { name: 'v-on', data() { return { title: 'v-on指令学习', msg: '我是div内部子节点', msg1: '我是div父节点', msg2: '我是div爷爷节点', msg3: '我是div曾祖父节点' } }, methods:{ click0(){ console.log("打印子节点"); }, click1(){ console.log("打印父节点"); }, click2(){ console.log("打印爷爷节点"); }, click3(){ console.log("打印曾祖父节点"); } } } </script> <style scoped> .title1 { text-align: left; } .div1{ float: left; } </style>
.once属性
点击事件将只会触发一次,通俗点说就是元素自身事件只能使用一次,第二次点击元素时候并不触发事件,但是不阻止事件冒泡。
本示例中第一次点击时打印子节点和父节点,第二次点击时并不打印子节点,仍然打印父节点及以上节点,示例代码和实力结果如下:
<template> <div> <p class="title1">{{title}}</p> <div class="div1" v-on:click="click3"> {{msg3}}<br/> <div class="div1" v-on:click="click2"> {{msg2}}<br/> <div class="div1" v-on:click="click1"> {{msg1}}<br/> <div v-on:click.once="click0">{{msg}}</div> </div> </div> </div> </div> </template> <script> export default { name: 'v-on', data() { return { title: 'v-on指令学习', msg: '我是div内部子节点', msg1: '我是div父节点', msg2: '我是div爷爷节点', msg3: '我是div曾祖父节点' } }, methods:{ click0(){ console.log("打印子节点"); }, click1(){ console.log("打印父节点"); }, click2(){ console.log("打印爷爷节点"); }, click3(){ console.log("打印曾祖父节点"); } } } </script> <style scoped> .title1 { text-align: left; } .div1{ float: left; } </style>
.passive属性
滚动事件的默认行为 (即滚动行为) 将会立即触发,而不会等待onScroll完成,这其中包含event.preventDefault()的情况
相关推荐:
以上是Vue中v-on指令简单事件绑定的属性分析(附代码)的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

JavaScript字符串替换方法详解及常见问题解答 本文将探讨两种在JavaScript中替换字符串字符的方法:在JavaScript代码内部替换和在网页HTML内部替换。 在JavaScript代码内部替换字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 该方法仅替换第一个匹配项。要替换所有匹配项,需使用正则表达式并添加全局标志g: str = str.replace(/fi

本教程向您展示了如何将自定义的Google搜索API集成到您的博客或网站中,提供了比标准WordPress主题搜索功能更精致的搜索体验。 令人惊讶的是简单!您将能够将搜索限制为Y

因此,在这里,您准备好了解所有称为Ajax的东西。但是,到底是什么? AJAX一词是指用于创建动态,交互式Web内容的一系列宽松的技术。 Ajax一词,最初由Jesse J创造

本文系列在2017年中期进行了最新信息和新示例。 在此JSON示例中,我们将研究如何使用JSON格式将简单值存储在文件中。 使用键值对符号,我们可以存储任何类型的

利用轻松的网页布局:8个基本插件 jQuery大大简化了网页布局。 本文重点介绍了简化该过程的八个功能强大的JQuery插件,对于手动网站创建特别有用

核心要点 JavaScript 中的 this 通常指代“拥有”该方法的对象,但具体取决于函数的调用方式。 没有当前对象时,this 指代全局对象。在 Web 浏览器中,它由 window 表示。 调用函数时,this 保持全局对象;但调用对象构造函数或其任何方法时,this 指代对象的实例。 可以使用 call()、apply() 和 bind() 等方法更改 this 的上下文。这些方法使用给定的 this 值和参数调用函数。 JavaScript 是一门优秀的编程语言。几年前,这句话可

jQuery是一个很棒的JavaScript框架。但是,与任何图书馆一样,有时有必要在引擎盖下发现发生了什么。也许是因为您正在追踪一个错误,或者只是对jQuery如何实现特定UI感到好奇

该帖子编写了有用的作弊表,参考指南,快速食谱以及用于Android,BlackBerry和iPhone应用程序开发的代码片段。 没有开发人员应该没有他们! 触摸手势参考指南(PDF) Desig的宝贵资源
