项目需求
(1)系统内页面出现水印;
(2)登录页面没有水印【备注:退出登录时,登录页面不会显示水印**】
创建水印
创建watermark.js文件
# 创建水印功能网上一大把,随便搜一下
'use strict'
const watermark = {}
const setWatermark = (str) => {
const id = '7.432756475.689573874'
if (document.getElementById(id) !== null) {
document.body.removeChild(document.getElementById(id))
}
const can = document.createElement('canvas')
can.width = 150
can.height = 120
const cans = can.getContext('2d')
cans.rotate(-20 * Math.PI / 180)
cans.font = '20px Vedana'
cans.fillStyle = 'rgba(200, 200, 200, 0.20)'
cans.textAlign = 'left'
cans.textBaseline = 'Middle'
cans.fillText(str, can.width / 3, can.height / 2)
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) => {
let id = setWatermark(str)
setInterval(() => {
if (document.getElementById(id) === null) {
id = setWatermark(str)
}
}, 500)
window.onresize = () => {
setWatermark(str)
}
}
export default watermark
具体实现
第一种做法: 在App.vue中引用或其他页面都可以
1.在App.vue文件中,导入该文件
import Watermark from '@/watermark'; //路径不要写错
2.在函数中调用,一种就可以
mounted: 写法
mounted() {
Watermark.set("水印内容")
}
created: 写法
created() {
Watermark.set('admin')
}
第二种做法: 配置js文件,在main.js文件中引入
本人通过配置 permission.js文件
import '@/permission' //路径不要写错哟
// permission主要代码
router.beforeEach(async(to, from, next) => {
const hasToken = getToken()
if (hasToken) {
if (to.path === '/login') {
next(`/login`)
}
}
})
router.afterEach((to) => {
const title = getToken()
if (title) {
Watermark.set(title) // 设置水印title
} else {
Watermark.out() // 清除水印
}
})
自己定义了一个去除水印的接口 watermark.js文件
// 在watermark.js文件中
const outWatermark = (id) => {
if (document.getElementById(id) !== null) {
const div = document.getElementById(id)
div.style.display = 'none'
}
}
watermark.out = () => {
const str = '7.432756475.689573874'
outWatermark(str)
}
注意内容:
我们一般在路由跳转的时候来进行用户的登录和权限的判断,所以我们可以将调用水印的方法放在router.afterEach()方法中,在router.beforeEach()方法中判断用户的登录和权限的判断,所以router.afterEach()方法中一定可以用户信息。
当然这些可能不是最优的解决方案,但希望能给你带来帮助。