Vue项目在页面添加水印及在某一个页面去除水印功能

项目需求

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

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

你可能感兴趣的:(vue.js,es6,node.js,typescript,javascript)