项目需求

(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()方法中一定可以用户信息。

当然这些可能不是最优的解决方案,但希望能给你带来帮助。