首页 > 其他 > 详细

vue点击其它页面 弹出层消失

时间:2019-04-06 10:27:21      阅读:193      评论:0      收藏:0      [点我收藏+]

遇到一个问题,点击表情图标,弹出表情框,点击其它部分就应该隐藏

 

首先,给子组件包一层

<div ref="emoji">
<emoji :getEmoji="getEmoji" ref="emoji"/>
</div>
 

然后,给document元素添加点击事件,如果点击的元素不在表情框内,就隐藏

mounted() {
this.cone();
document.addEventListener("click", e => {
//console.log(this.$refs.emoji.contains(e.target));
if(!this.$refs.emoji.contains(e.target)) {
this.getEmoji = false
}
});
},

 

点击表情图标,会显示表情框,但是会冒泡,导致又发生上面事件,又把表情框隐藏了,所以会点击弹不出,应该加stop阻止冒泡

<div class="biaoqing" @click.stop="showEmoji">
<i class="iconfont icon-biaoqing"></i>
</div>
 
//表情框显示是否
showEmoji() {
this.getEmoji = !this.getEmoji;
},

vue点击其它页面 弹出层消失

原文:https://www.cnblogs.com/kimm/p/10660635.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!