vue.js(5)--事件修饰符
程序员文章站
2022-03-20 22:10:03
vue中的事件修饰符(.stop、.prevent、.self、.capture、.once) (1)实例代码 (2)摘要 使用.stop阻止事件的冒泡行为。 使用.prevent阻止事件的默认行为。 使用.self实现只有点击当前元素才会触发事件处理函数。 使用.capture实现捕获触发事件的机 ......
vue中的事件修饰符(.stop、.prevent、.self、.capture、.once)
(1)实例代码
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="x-ua-compatible" content="ie=edge"> <title>事件修饰符</title> <script src="../lib/vue.js"></script> <style> .app{ width: 200px; height: 200px; background: red; } </style> </head> <body> <!-- <div class="app" @click.capture="outclick"> --> <!-- 使用.capture实现捕获触发事件的机制,即从外部事件开始执行 --> <div class="app" @click.self="outclick"> <!-- 使用.self实现只有点击当前元素才会触发事件处理函数--> <input type="button" value="按钮1" @click.stop="innerclick"> <!-- 使用.stop阻止事件的冒泡行为 --> <input type="button" value="按钮2" @click.once="innerclick"> <!-- 使用.once实现事件的触发次数为一次 --> <a href="https://www.baidu.com/" @click.prevent.stop="aclick">有事找百度</a> <!-- 使用.prevent阻止事件的默认行为 --> </div> <script> var vm = new vue({ el:".app", methods:{ outclick(){ alert('我是外面的事件'); }, innerclick(){ alert('我是内部的事件'); }, aclick(){ alert('我是超链接的事件'); } } }) </script> </body> </html>
(2)摘要
使用.stop阻止事件的冒泡行为。
使用.prevent阻止事件的默认行为。
使用.self实现只有点击当前元素才会触发事件处理函数。
使用.capture实现捕获触发事件的机制,即从外部事件开始执行。
使用.once实现事件的触发次数为一次。
需要特别注意.stop和.self的区别:.stop是阻止除了自己之外所有的冒泡事件,而.self是控制自己被点击才会触发事件处理函数,阻止自己被冒泡所影响。