经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » Vue.js » 查看文章
Vue之全局水印的实现示例
来源:jb51  时间:2021/7/19 11:49:37  对本文有异议

【需求】系统内页面显示水印,登录页面没有水印(退出登录时,登录页面不会显示水印)

1.创建水印Js文件

  1. /*
  2. * @Author: 刘小二
  3. * @Date: 2021-07-15 14:43:27
  4. * @LastEditTime: 2021-07-15 15:00:27
  5. * @LastEditors: Please set LastEditors
  6. * @Description: 添加水印
  7. * @FilePath: /huashijc_MeetingSys/src/common/warterMark.js
  8. */
  9. 'use strict'
  10. let watermark = {}
  11. let setWatermark = (str) => {
  12. let id = '1.23452384164.123412415'
  13. if (document.getElementById(id) !== null) {
  14. document.body.removeChild(document.getElementById(id))
  15. }
  16. let can = document.createElement('canvas')
  17. can.width = 250
  18. can.height = 120
  19. let cans = can.getContext('2d')
  20. cans.rotate(-15 * Math.PI / 150)
  21. cans.font = '20px Vedana'
  22. cans.fillStyle = 'rgba(200, 200, 200, 0.20)'
  23. cans.textAlign = 'left'
  24. cans.textBaseline = 'Middle'
  25. cans.fillText(str, can.width / 8, can.height / 2)
  26. let div = document.createElement('div')
  27. div.id = id
  28. div.style.pointerEvents = 'none'
  29. div.style.top = '35px'
  30. div.style.left = '0px'
  31. div.style.position = 'fixed'
  32. div.style.zIndex = '100000'
  33. div.style.width = document.documentElement.clientWidth + 'px'
  34. div.style.height = document.documentElement.clientHeight + 'px'
  35. div.style.background = 'url(' + can.toDataURL('image/png') + ') left top repeat'
  36. document.body.appendChild(div)
  37. return id
  38. }
  39. // 该方法只允许调用一次
  40. watermark.set = (str) => {
  41. let id = setWatermark(str)
  42. setInterval(() => {
  43. if (document.getElementById(id) === null) {
  44. id = setWatermark(str)
  45. }
  46. }, 500)
  47. window.onresize = () => {
  48. setWatermark(str)
  49. }
  50. }
  51.  
  52. const outWatermark = (id) => {
  53. if (document.getElementById(id) !== null) {
  54. const div = document.getElementById(id)
  55. div.style.display = 'none'
  56. }
  57. }
  58. watermark.out = () => {
  59. const str = '1.23452384164.123412415'
  60. outWatermark(str)
  61. }
  62. export default watermark

2.引入操作

2.1 在App.vue中引用或其他页面

  1. // 1.在App.vue文件中,导入该文件
  2. import Watemark from '@/common/watermark';
  3.  
  4. computed: {
  5. userName() {
  6. const name = this.$store.state.user.name
  7. return (name && name.length > 0) ? name : '未获取到用户名'
  8. }
  9. },
  10. mounted() {
  11. Watermark.set(this.userName)
  12. }
  13.  
  14. // 2.在其他页面引用
  15. import Watemark from '@/common/watermark';
  16.  
  17. created() {
  18. Watermark.set('admin')
  19. }

2.2 在router配置文件中引用

  1. const outWatermark = (id) => {
  2. if (document.getElementById(id) !== null) {
  3. const div = document.getElementById(id)
  4. div.style.display = 'none'
  5. }
  6. }
  7.  
  8. router.afterEach((to) => {
  9. if(to.path == '/'){
  10. Watermark.out() // 清除水印
  11. }else{
  12. Watermark.set('未获取到用户名') // 设置水印title
  13. }
  14. });
  15.  

到此这篇关于Vue之全局水印的实现示例的文章就介绍到这了,更多相关Vue 全局水印内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号