最近在做项目,有这样要求,需要在指定容器中添加水印,也可不设置容器,如果没有容器,则添加在整个页面中,即 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 > <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 使用,如果大家有更好的方法,欢迎留言交流。