小程序开发root-portal弹窗组件

在我们布局的时候经常会遇到以下问题:

在制作一个弹窗的时候会出现因为有元素设置的z-index层级比遮罩层高,导致遮罩层没办法完全遮住页面,下面就是一个例子

wxml:

xml 复制代码
<view>
  <view class="box1"></view>
  <view class="box2">
    <view class="mask"></view>
  </view>
</view>

wxcss:

css 复制代码
.box1{
  position: relative;
  width: 200rpx;
  height: 200rpx;
  background-color: violet;
  z-index: 10;
}
.box2{
  position: relative;
  top: -100rpx;
  left: 100rpx;
  width: 400rpx;
  height: 400rpx;
  background-color: palevioletred;
  z-index: 9;
}
​
.box2 .mask{
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 10000;
}

效果:

那出现这种情况的原因是什么呢?

因为box1的z-index比box2的z-index大,所以不管mask的z-index多大都会被box1压着。

那我们应该怎么解决这个问题呢?

有两种处理方式:

①可以将box2删除层级z-index或者删除box2,但是这种处理方式会改变原来的页面布局

②使用root-portal组件

用root-portal标签把遮罩层包裹住:

xml 复制代码
<view>
  <view class="box1"></view>
  <view class="box2">
    <root-portal>
       <view class="mask"></view>
    </root-portal>
  </view>
</view>

但是要注意,因为root-portal使整个子树从页面中脱离出来,类似于在 CSS 中使用 fixed position 的效果。主要用于制作弹窗、弹出层等。所以现在如果还是在原来的局部页面wxss中设置样式是没有任何效果的,应该在全局的app.wxss中设置样式:

css 复制代码
.mask{
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 10000;
}

现在就实现遮罩层的效果了:

相关推荐
糕冷小美n6 小时前
elementuivue2表格不覆盖整个表格添加固定属性
前端·javascript·elementui
小哥不太逍遥6 小时前
Technical Report 2024
java·服务器·前端
沐墨染6 小时前
黑词分析与可疑对话挖掘组件的设计与实现
前端·elementui·数据挖掘·数据分析·vue·visual studio code
anOnion6 小时前
构建无障碍组件之Disclosure Pattern
前端·html·交互设计
threerocks6 小时前
前端将死,Agent 永生
前端·人工智能·ai编程
问道飞鱼7 小时前
【前端知识】Vite用法从入门到实战
前端·vite·项目构建
爱上妖精的尾巴7 小时前
8-10 WPS JSA 正则表达式:贪婪匹配
服务器·前端·javascript·正则表达式·wps·jsa
Aliex_git8 小时前
浏览器 API 兼容性解决方案
前端·笔记·学习
独泪了无痕8 小时前
useStorage:本地数据持久化利器
前端·vue.js
程序员林北北9 小时前
【前端进阶之旅】JavaScript 一些常用的简写技巧
开发语言·前端·javascript