何为默认事件?好比 a 会跳转页面,submit 会提交表单等。javascript
e.preventDefault()函数。html
<a href="http://www.baidu.com" onclick="stopDef(event)">百度</a>
function stopDef(e){ e.preventDefault(); }
.prevent 是vue 的内置修饰符,调用了 event.preventDefault()阻止默认事件前端
<div id="app"> <a href="http://www.baidu.com" @click.prevent="vueStopDef()">百度</a> </div>
window.onload = function(){ new Vue({ el:"#app", methods:{ vueStopDef(){ console.log("vue.js经过 .prevent 阻止默认事件") } } }); }
何为事件冒泡?执行下段代码:vue
<!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>Document</title> <style> .div1{ width: 500px; height: 500px; border: 1px solid black; } .div2{ width: 400px; height: 400px; border: 1px solid black; } .div3{ width: 300px; height: 300px; border: 1px solid black; } .div4{ width: 200px; height: 200px; border: 1px solid black; } .div5{ width: 100px; height: 100px; border: 1px solid black; } </style> <script src="../js/vue.js"></script> <script> function fun01(){ console.log("点击了div1"); }; function fun02(){ console.log("点击了div2"); }; function fun03(){ console.log("点击了div3"); }; function fun04(){ console.log("点击了div4"); }; function fun05(){ console.log("点击了div5"); }; window.onload = function (){ } </script> </head> <body> <div class="div1" onclick="fun01()"> <div class="div2" onclick="fun02()"> <div class="div3" onclick="fun03()"> <div class="div4" onclick="fun04()"> <div class="div5" onclick="fun05()"> div05 </div> div04 </div> div03 </div> div02 </div> div01 </div> </body> </html>
当点击div05时,同时按顺序触发 div0五、div0四、div0三、div0二、div01;当点击div03的时候 ,同时按顺序出发div0三、div0二、div01 等。从内层div一层一层触发外层div事件,这种现象就是事件冒泡。 java
e.stopPropagation()。上述代码中,在定义fun05()改为fun05(e),同时在方法中加入e.stopPropagation()。在调用是 onclick=“fun05(event)”。当点击div05时,不会冒泡触发外层事件。app
.stop 是vue 的内置修饰符 调用了 e.stopPropagation()。阻止冒泡事件发生。下段代码中div5和div3出发点击事件时使用 .stop ,阻止冒泡事件发生。当点击div05 活着div03时,不会触发冒泡事件。函数
<div id="app" class="div1" @click="fun01"> <div class="div2" @click="fun02"> <div class="div3" @click.stop="fun03"> <div class="div4" @click="fun04"> <div class="div5" @click.stop="fun05"> div05 </div> div04 </div> div03 </div> div02 </div> div01 </div>
window.onload = function (){ new Vue({ el:"#app", methods:{ fun01(){ console.log("点击了div1"); }, fun02(){ console.log("点击了div2"); }, fun03(){ console.log("点击了div3"); }, fun04(){ console.log("点击了div4"); }, fun05(){ console.log("点击了div5"); } } }); }
可是,仍是有点问题,上段代码运行后,由于对div5 和div3阻止了冒泡事件。可是,当点击div4 的时候,div4发生冒泡事件,同时出发了div3的点击事件(后面的被div阻止了)。也就是说,即便本身自己使用.stop阻止冒泡事件(不去触发外层事件),可是自身仍是会被其它(内层事件)触发。这个时候,就须要 .self。ui
.self 是vue 的内置修饰符 对于所指定的元素 只有当前元素自己能够触发事件,修饰符能够连写。即,将上段代码div3绑定事件改成spa
<div class="div3" @click.stop.self="fun03">
此时,能出发 div3 的点击事件只有在点击div3时这一种状况。code
至此,完毕,感谢阅读。若是您以为本篇博客对您有用,记得给个赞哟
一入前端深似海,今后时间是路人。
--论前端的技术更新