vue---点击空白处隐藏div

需求说明:最近在写移动端,UI设计给出顶部导航设计,点击左边的默认图片,出现菜单栏的div盒子,于是我的代码设计如下:

<div class="left-nav" @click="handleChange">
	<div v-if="!activeStatus" class="init-menu"></div>
	<div v-else class="active-menu">/菜单栏/</div>
</div>
handleChange(){
	this.activeStatus = !this.activeStatus
}

可以看到我是在他们父盒子上添加点击事件去控制菜单栏的显示或者隐藏,在菜单栏里面做了一个关闭的按钮,点击关闭隐藏菜单栏,显示默认图片

项目经理看到效果后提出:在此基础上增加点击空白处也能关闭菜单栏。
好吧

那怎么实现点击空白处关闭菜单栏尼?

1.要保留菜单栏的关闭按钮,所以父盒子 left-nav的点击事件不能取消。
2.要在页面内的空白处,也就是说这个页面的任意位置,所以必须是给document添加点击事件。
3.可以看到层级:document > 父盒子 left-nav 两个都有点击事件。

想实现的效果 就是,父盒子 left-nav 的点击事件控制菜单栏的隐藏或者显示,而doument的点击事件是隐藏菜单栏,在点击父盒子的时候不能触发document的点击事件。

也就是说 点击子元素区域的的时候,不触发父级元素的点击事件,这时候就可以用到@click.stop,是用来阻止事件冒泡

最后的代码呈现:

<div class="left-nav" @click.stop="handleChange">
	<div v-if="!activeStatus" class="init-menu"></div>
	<div v-else class="active-menu">/菜单栏/</div>
</div>
mounted(){
	document.addEventListener('click', this.handleClose)
},
methods:{
	handleClose(){
		this.activeStatus = false
	},
	handleChange(){
		this.activeStatus = !this.activeStatus
	}
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值