Skip to content

Watermark 水印

介绍

在页面上添加特定的文字或图案作为水印,可用于防止信息盗用。请升级 @szhn/dh-design-mobile 到最新版本来使用该组件。

引入

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

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

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

代码演示

文字水印

通过 content 属性来设置水印的文字。

html
<van-watermark content="dh-design-mobile" />

图片水印

通过 image 属性来设置水印图片,并使用 opacity 来调整水印的整体透明度。

html
<van-watermark
  image="https://fastly.jsdelivr.net/npm/@vant/assets/vant-watermark.png"
  opacity="0.2"
/>

自定义间隔

通过 gap-xgap-y 属性来控制多个重复水印之间的间隔。

html
<van-watermark
  image="https://fastly.jsdelivr.net/npm/@vant/assets/vant-watermark.png"
  :gap-x="30"
  :gap-y="10"
  opacity="0.2"
/>

自定义倾斜角度

通过 rotate 属性来控制水印的倾斜角度,默认值为-22

html
<van-watermark
  image="https://fastly.jsdelivr.net/npm/@vant/assets/vant-watermark.png"
  rotate="22"
  opacity="0.2"
/>

显示范围

通过 full-page 属性来控制水印的显示范围。

html
<van-watermark
  image="https://fastly.jsdelivr.net/npm/@vant/assets/vant-watermark.png"
  opacity="0.2"
  :full-page="true"
/>

HTML 水印

通过 content 插槽可以直接传入 HTML 作为水印。HTML 中的样式仅支持行内样式,同时不支持传入自闭合标签。

html
<van-watermark :width="150">
  <template #content>
    <div style="background: linear-gradient(45deg, #000 0, #000 50%, #fff 50%)">
      <p style="mix-blend-mode: difference; color: #fff">dh-design-mobile watermark</p>
    </div>
  </template>
</van-watermark>

API

Props

参数说明类型默认值
width水印宽度number100
height水印高度number100
z-index水印的 z-indexnumber | string100
content文字水印的内容string-
image图片水印的内容,如果与 content 同时传入,优先使用图片水印string-
rotate水印的旋转角度number | string-22
full-page水印是否全屏显示booleanfalse
gap-x水印之间的水平间隔number0
gap-y水印之间的垂直间隔number0
text-color文字水印的颜色string#dcdee0
opacity水印的透明度number | string-

Slots

名称说明
contentHTML 水印的内容,仅支持行内样式,同时不支持传入自闭合标签,优先级高于 contentimage 属性

类型定义

组件导出以下类型定义:

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

主题定制

样式变量

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

名称默认值描述
--van-watermark-z-index100根节点的 z-index 层级