Vue项目为页面添加水印效果
AI 概述
实现方法使用方法结语
最近在做项目,有这样要求,需要在指定容器中添加水印,也可不设置容器,如果没有容器,则添加在整个页面中,即 body,当接到这个需求的时候我第一想的方法就是用 canvas 来实现,话不多说搞起来。
我项目效果如下:
实现方法
首先我们在 utils 文件中新建一个 waterMark.js 文...
目录
最近在做项目,有这样要求,需要在指定容器中添加水印,也可不设置容器,如果没有容器,则添加在整个页面中,即 body,当接到这个需求的时候我第一想的方法就是用 canvas 来实现,话不多说搞起来。
我项目效果如下:

实现方法
首先我们在 utils 文件中新建一个 waterMark.js 文件。
let watermark = {};
let setWatermark = (text, sourceBody) => {
let id = 'watermark_fjq_' + parseInt(Math.random() * 100000);
if (document.getElementById(id) !== null) {
document.body.removeChild(document.getElementById(id));
}
//水印图片
let can = document.createElement('canvas');
can.width = 390; // 单个水印大小
can.height = 180; // 单个水印大小
let cans = can.getContext('2d');
cans.rotate((-20 * Math.PI) / 180);
cans.font = '14px Vedana';
cans.fillStyle = 'rgba(200, 200, 200, 0.20)'; //水印颜色
cans.textAlign = 'left';
cans.textBaseline = 'Middle';
cans.fillText(text, can.width / 20, can.height);
//设置插入 div 样式
let water_div = document.createElement('div');
water_div.id = id;
water_div.style.pointerEvents = 'none';
water_div.style.overflow = 'hidden';
water_div.style.background = 'url(' + can.toDataURL('image/png') + ') left top repeat';
if (sourceBody) {
sourceBody.style.position = 'relative';
water_div.style.width = '100%';
water_div.style.height = '100%';
water_div.style.position = 'absolute';
water_div.style.top = '0';
water_div.style.left = '0';
sourceBody.appendChild(water_div);
} else {
water_div.style.top = '3px';
water_div.style.left = '200px';
water_div.style.position = 'fixed';
water_div.style.zIndex = '9999';
water_div.style.width = document.documentElement.offsetWidth + 'px';
water_div.style.height = document.documentElement.offsetHeight + 'px';
document.body.appendChild(water_div);
}
return id;
};
/**
* 该方法只允许调用一次
* @param:
* @text == 水印内容
* @sourceBody == 水印添加在哪里,不传就是 body
* */
watermark.set = (text, sourceBody) => {
setTimeout(() => {
setWatermark(text, sourceBody);
}, 1000); //延迟加载
};
export default watermark;
使用方法
在 main.js 中引入 waterMark.js。
// 引入水印文件地址 import watermark from '@/utils/waterMark' Vue.prototype.$watermark = watermark
如果我们在指定页面中使用:
this.$watermark.set(text,dom)
| 参数 | 说明 | 是否必填 |
|---|---|---|
| text | 水印内容 | 是 |
| dom | 水印容器。若不传,则全屏水印,若传,则指定容器。 | 否 |
比如,在指定容器水印:
<template>
<div class="page">
<div ref="content"></div>
</div>
</template>
<script>
export default {
data() {
return {};
},
mounted(){
this.$watermark.set("码云笔记",this.$refs.content)
},
beforeDestroy() {
this.$watermark.set("",this.$refs.content);
}
};
</script>
我这里需要给整个项目页面添加水印,所以在 App.vue 文件中引入:
<template>
<router-view />
</template>
<script>
export default {
name: 'App',
data() {
return {};
},
mounted() {
this.$watermark.set('码云笔记');
},
beforeDestroy() {
this.$watermark.set('');
},
};
</script>
结语
以上就是我在 Vue 项目为页面添加水印效果,都是实际项目中使用过的,大家可以直接 CV 使用,如果大家有更好的方法,欢迎留言交流。
以上关于Vue项目为页面添加水印效果的文章就介绍到这了,更多相关内容请搜索码云笔记以前的文章或继续浏览下面的相关文章,希望大家以后多多支持码云笔记。
声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 admin@mybj123.com 进行投诉反馈,一经查实,立即处理!
重要:如软件存在付费、会员、充值等,均属软件开发者或所属公司行为,与本站无关,网友需自行判断
码云笔记 » Vue项目为页面添加水印效果
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 admin@mybj123.com 进行投诉反馈,一经查实,立即处理!
重要:如软件存在付费、会员、充值等,均属软件开发者或所属公司行为,与本站无关,网友需自行判断
码云笔记 » Vue项目为页面添加水印效果
微信
支付宝