Skip to content

Overlay 遮罩层

介绍

创建一个遮罩层,用于强调特定的页面元素,并阻止用户进行其他操作。

引入

通过以下方式来引入组件。

js
import { createApp } from 'vue';
import { Overlay } from '@szhn/dh-design-mobile';

const app = createApp();
app.use(Overlay);

代码演示

基础用法

html
<van-button type="primary" text="显示遮罩层" @click="show = true" />
<van-overlay :show="show" @click="show = false" />
js
import { ref } from 'vue';

export default {
  setup() {
    const show = ref(false);
    return { show };
  },
};

嵌入内容

通过默认插槽可以在遮罩层上嵌入任意内容。

html
<van-overlay :show="show" @click="show = false">
  <div class="wrapper">
    <div class="block" @click.stop />
  </div>
</van-overlay>

<style>
  .wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
  }

  .block {
    width: 120px;
    height: 120px;
    background-color: #fff;
  }
</style>

设置 z-index

Overlay 组件默认的 z-index 层级为 1,你可以通过 z-index 属性设置它的 z-index 层级。

html
<van-overlay z-index="100" />

API

Props

参数说明类型默认值
show是否展示遮罩层booleanfalse
z-indexz-index 层级number | string1
duration动画时长,单位秒,设置为 0 可以禁用动画number | string0.3
class-name自定义类名string-
custom-style自定义样式object-
lock-scroll是否锁定背景滚动,锁定时蒙层里的内容也将无法滚动booleantrue
lazy-render是否在显示时才渲染节点booleantrue
teleport指定挂载的节点,等同于 Teleport 组件的 to 属性string | Element-

Events

事件名说明回调参数
click点击时触发event: MouseEvent

Slots

名称说明
default默认插槽,用于在遮罩层上方嵌入内容

类型定义

组件导出以下类型定义:

ts
import type { OverlayProps } from '@szhn/dh-design-mobile';

主题定制

样式变量

组件提供了下列 CSS 变量,可用于自定义样式,使用方法请参考 ConfigProvider 组件

名称默认值描述
--van-overlay-z-index1-
--van-overlay-backgroundrgba(0, 0, 0, 0.7)-