vue 阻止事件冒泡和捕获

@click.stop : 阻止事件冒泡

@click.prevent : 阻止事件默认行为

@click.self : 事件只作用在元素本身,而不是其子元素

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

1. js 事件的三阶段

在这里插入图片描述

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

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

@click.stop : 阻止事件冒泡
@click.prevent : 阻止事件默认行为
@click.self : 事件只作用在元素本身,而不是其子元素

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

补充其他修饰符

@click.capture : 使用事件捕获模式
@click.once : 事件只触发一次 2.1.4新增
@scroll.passive : 告诉浏览器这个事件的默认行为不会被取消 2.3.0新增
@keyup.enter : 按键修饰符,enter被按下的时候触发
@click.ctrl : 系统修饰符,Ctrl 被按下的时候触发 2.1.0新增
@click.ctrl.exact : 有且只有 Ctrl 被按下的时候才触发 2.5.0新增
<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/" 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对象

猜你喜欢

转载自blog.csdn.net/qq_39900031/article/details/130611058