vue实现点击其他地方隐藏div(事件冒泡)

2019-12-06  本文已影响0人  Hello杨先生

vue实现点击其他地方隐藏div

方法一:

通过监听事件

<pre style="margin-top: 0px; margin-bottom: 0px; white-space: pre-wrap; overflow-wrap: break-word; font-family: "Courier New" !important; font-size: 12px !important;">document.addEventListener('click',function(e){
if(e.target.className!='usermessage'){
that.userClick=false;
}
})</pre>

方法二(比较好):

给最外层的div加个点击事件 @click="userClick=false"

给点击的元素上面加上:@click.stop="userClick=!userClick"

方法三:

<template>

<div class="page" @click="hide">


<button @click.stop="show">点击显示div</button>


<div @click.stop>
...
</div>

</div>
<template>

<script>
export default {
methods:{
show(){},
hide(){}
}

}
</script>

总结:

通过vue.js 事件的.stop修饰符可以阻止事件继续冒泡传播,也可以使用原生js事件的event.stopPropagation()方法。
通过向指定的div添加.stop,可以实现只有点击非该div内的元素时,才会往上冒泡至page,从而实现点击其他地方隐藏div。
要向触发显示div的按钮添加.stop,否则一点击按钮,触发show()之后传播到page,立马就会触发hide(),div就无法显示。

复制过来的
这是原网页
https://www.cnblogs.com/wasbg/p/11395611.html

上一篇下一篇

猜你喜欢

热点阅读