vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > vue阻止事件冒泡和捕获

vue阻止事件冒泡和捕获方式

作者:yujkss

这篇文章主要介绍了vue阻止事件冒泡和捕获方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

要想了解 VUE 阻止事件冒泡和捕获方法,首先要了解一下 JS 事件和 JS 阻止事件冒泡,捕获方法

1、js 事件的三阶段

捕获阶段

目标阶段:执行当前对象的事件处理程序

冒泡阶段

2、js 阻止事件冒泡,捕获

<a @click.stop="doThis">阻止单击事件继续传播</a>
<form @submit.prevent="onSubmit">提交事件不再重载页面</form>
<a @click.stop.prevent="doThat">修饰符可以串联</a>
<div @click.self="doThat">只当在 event.target 是当前元素自身时触发处理函数.即事件不是从内部元素触发的</div>

补充其他修饰符

<div @click.capture="doThis">添加事件监听器时使用事件捕获模式,即元素自身触发的事件先在此处处理,然后才交由内部元素进行处理</div>
<a @click.once="doThis">点击事件将只会触发一次</a>
<div @scroll.passive="onScroll">scroll事件不会取消默认的滚动行为</div>
<input @keyup.13="submit" placeholder="只有在 keyCode 是 13 时调用 vm.submit()">
<button @click.ctrl="onClick">即使 Alt 或 Shift 被一同按下时也会触发</button>
<button @click.ctrl.exact="onCtrlClick">有且只有 Ctrl 被按下的时候才触发</button>
<button @click.exact="onClick">没有任何系统修饰符被按下的时候才触发</button>

使用修饰符时,顺序很重要,相应的代码会以同样的顺序产生。

例如:用 @click.prevent.self 会阻止所有的点击,而@click.self.prevent 只会阻止元素上的点击。

3、JavaScript基础知识:preventDefault和stopPropagation

preventDefault()事件方法

【定义】:如果事件是可取消的,则 preventDefault() 方法会取消该事件,这意味着属于该事件的默认操作将不会发生。

单击“提交”按钮,阻止其提交表

<form action="https://www.baidu.com/"  method="post">
     <input type="submit" value="登录">
</form>

<script>
        console.log(document.forms[0]);
        document.forms[0].onsubmit =  function(){
            console.log(event);
            console.log(event.cancelable);//检测事件是否可以取消--> Boolean
            event.preventDefault();//阻止默认事件  单
            //return false; // 也可以阻止默认事件
           
        }
</script>

单击链接,防止链接跟随 URL

<a href="https://www.baidu.com/" rel="external nofollow"  id="a">点我跳转</a>

<script>
		let a = document.getElementById('a');
        a.onclick = function(){
            console.log(event);
            console.log(event.cancelable);//检测事件是否可以取消 -->Boolean
            event.preventDefault();//阻止默认事件
            //return false; // 也可以阻止默认事件
        }
</script>

非所有活动都可以取消。请使用 cancelable 属性 来确定事件是否可取消。

如上面两个示例中,其返回值为Boolean,可以取消–>true,否则为–>false

【注】preventDefault() 方法不会阻止事件通过 DOM 进一步传播。请使用 stopPropagation() 方法来解决

stopPropagation()事件方法

stopPropagation() 方法防止调用相同事件的传播

【传播阶段】传播意味着向上冒泡到父元素或向下捕获到子元素或元素目标本体 三个3️⃣ 阶段

【注】添加事件(HTML属性事件,JavaScript元素事件,addEventLisenter,attachEvent(IE))默认都是冒泡,捕获需要**addEventLisenter()**显式的指定第三个参数为true(事件捕获)

//样式
<style>
        div {
            padding: 50px;
            background-color: rgba(255, 0, 0, 0.2);
            text-align: center;
            cursor: pointer;
        }
</style>

//HTML
	<p>Click DIV 1:</p>
    <div onclick="func2()">DIV 2
        <div onclick="func1(event)">DIV 1</div>
    </div>
    
//script
<script>
        function func1(event) {
            alert("DIV 1");
            event.stopPropagation();//阻止事件传播
        }

        function func2() {
            alert("DIV 2");
        }
</script>

不阻止事件传播的话,当点击DIV2时,事件会继续向上传播,触发父元素DIV1上的func2(),然后会继续向上传播,直到window对象

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文