一 效果图
二 全局加水印
https://blog.csdn.net/qq_32917123/article/details/87253716参考这篇文章
三 某个组件页面添加水印
在离开页面时候,置空就可以了,反之等于全局加入
<template>
<div class="about">
<h1>This is an about page</h1>
</div>
</template>
<script>
import Watermark from '@/watermark.js'
export default {
mounted: function () {
Watermark.set('刘芳蕊')
},
beforeDestroy () {
Watermark.set('')
}
}
</script>
四 添加多行水印
'use strict'
const watermark = {}
const setWatermark = (str = null, str1 = null) => { //传入多个str 或者传入一个对象
const id = '1.23452384164.123412415'
if (document.getElementById(id) !== null) {
document.body.removeChild(document.getElementById(id))
}
const can = document.createElement('canvas')
can.width = 450
can.height = 300
const cans = can.getContext('2d')
cans.rotate(-20 * Math.PI / 180)
cans.font = '20px Vedana'
cans.fillStyle = 'rgba(200, 200, 200, 1)'
cans.textAlign = 'left'
cans.textBaseline = 'Middle'
cans.fillText(str, can.width / 3, can.height / 2)
cans.fillText(str1, can.width / 3, can.height / 1.7) //这里渲染多行就可以展示多行,具体效果看上图,这里要调整高度的比例就可以做到换行的效果
const div = document.createElement('div')
div.id = id
div.style.pointerEvents = 'none'
div.style.top = '70px'
div.style.left = '0px'
div.style.position = 'fixed'
div.style.zIndex = '-100000' //这里设置层级 设为负值可以在页面下层
div.style.width = document.documentElement.clientWidth - 100 + 'px'
div.style.height = document.documentElement.clientHeight - 100 + 'px'
div.style.background = 'url(' + can.toDataURL('image/png') + ') left top repeat'
document.body.appendChild(div)
return id
}
// 该方法只允许调用一次
watermark.set = (str, str1) => { //这里要把传入的参数传进来
let id = setWatermark(str, str1)
setInterval(() => {
if (document.getElementById(id) === null) {
id = setWatermark(str, str1)
}
}, 500)
window.onresize = () => {
setWatermark(str, str1)
}
}
export default watermark
具体看代码注释,页面传入值的话就是
<template>
<div class="about">
<h1>This is an about page</h1>
</div>
</template>
<script>
import Watermark from '@/watermark.js'
export default {
mounted: function () {
Watermark.set('刘芳蕊', '[email protected]')
},
beforeDestroy () {
Watermark.set('', '')
}
}
</script>
加油加油