实现uniapp遮罩层

首先uniapp没有官方的遮罩层mask组件, 需要手搓一个。

//结构	
<view class="mask" v-if="isshowmask" @click="closemask" @touchmove.stop.prevent="">	
<image :src="image"  class="qcodeimg" ></image>
</view>


// 样式
	.mask{
		position: fixed;
		top:0;
		left:0;
		z-index:999;
		width:100%;
		height:100vh;
		background:rgba(0,0,0,0.4);
		display: flex;
		justify-content: center;
		align-items: center;
		.qcodeimg{
			width: 600rpx;
			height: 600rpx;
		}
	}

通过isshowmask控制遮罩层的显示。

这样做会有两个问题:

1.遮罩层中经常要显示东西,此时点击显示内容区域也会关闭遮罩层

2.遮罩层下方的页面内容依旧可以点击和滑动

解决方法:

  1. 阻止内容区域的冒泡事件,给内容区域添加 @click.stop
  2. 给遮罩层添加@touchmove.stop.prevent="" 这种方法是官方推荐的

介绍 | uni-app官网uni-app,uniCloud,serverlessicon-default.png?t=N7T8https://uniapp.dcloud.net.cn/tutorial/vue-basics.html#%E4%BA%8B%E4%BB%B6%E4%BF%AE%E9%A5%B0%E7%AC%A6

修改完成后的代码:

// 结构
<view class="mask" v-if="isshowmask" @click="closemask" @touchmove.stop.prevent="">
				<image :src="image"  class="qcodeimg" @click.stop></image>
		</view>

// 样式
	.mask{
		position: fixed;
		top:0;
		left:0;
		z-index:999;
		width:100%;
		height:100vh;
		background:rgba(0,0,0,0.4);
		display: flex;
		justify-content: center;
		align-items: center;
		.qcodeimg{
			width: 600rpx;
			height: 600rpx;
		}
	}

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值