vue如何实现水印效果
发表于:2025-02-22 作者:千家信息网编辑
千家信息网最后更新 2025年02月22日,这篇文章给大家分享的是有关vue如何实现水印效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言:vue项目中使用水印效果,可指定容器效果图:1、不指定容器2、指定容器实
千家信息网最后更新 2025年02月22日vue如何实现水印效果
这篇文章给大家分享的是有关vue如何实现水印效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
前言:
vue项目中使用水印效果,可指定容器
效果图:
1、不指定容器
2、指定容器
实现方法:
1、新建一个配置文件 watermark.js ,可放util,也可放别的地方
let watermark = {} let setWatermark = (text, sourceBody) => { let id = Math.random()*10000+'-'+Math.random()*10000+'/'+Math.random()*10000 if (document.getElementById(id) !== null) { document.body.removeChild(document.getElementById(id)) } let can = document.createElement('canvas') can.width = 150 can.height = 120 let cans = can.getContext('2d') cans.rotate(-20 * Math.PI / 180) cans.font = '15px Vedana' cans.fillStyle = 'rgba(0, 0, 0, .5)' cans.textAlign = 'left' cans.textBaseline = 'Middle' cans.fillText(text, can.width / 20, can.height ) let water_div = document.createElement('div') water_div.id = id water_div.style.pointerEvents = 'none' water_div.style.background = 'url(' + can.toDataURL('image/png') + ') left top repeat' if(sourceBody){ water_div.style.width = '100%' water_div.style.height = '100%' sourceBody.appendChild(water_div) }else{ water_div.style.top = '3px' water_div.style.left = '0px' water_div.style.position = 'fixed' water_div.style.zIndex = '100000' water_div.style.width = document.documentElement.clientWidth + 'px' water_div.style.height = document.documentElement.clientHeight + 'px' document.body.appendChild(water_div) } return id} /** * 该方法只允许调用一次 * @param: * @text == 水印内容 * @sourceBody == 水印添加在哪里,不传就是body * */watermark.set = (text, sourceBody) => { let id = setWatermark(text, sourceBody) setInterval(() => { if (document.getElementById(id) === null) { id = setWatermark(text, sourceBody) } }, 2000) _window.onresize = () => { setWatermark(text, sourceBody) }} export default watermark
2、在main.js中全局配置
// 水印import watermark from './utils/watermark.js'Vue.prototype.$watermark = watermark
3、页面中使用-全屏水印
this.$watermark.set("浩星2731")
4、页面中使用-指定容器
点我添加水印 addWatermark(){ this.$watermark.set("浩星2731",this.$refs.content) }5、如果觉得字体之间的距离太大了,改这个属性就行了
can.width = 150can.height = 120感谢各位的阅读!关于"vue如何实现水印效果"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
水印 效果 容器 内容 方法 更多 篇文章 页面 浩星 配置 不错 实用 之间 全局 前言 地方 字体 就是 属性 效果图 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 软件开发很苦吗 计算机专业和网络技术哪个好学 微商软件开发订制 宝马互联网创新科技 运营商的网络服务器层级关系 电子商务数据库销售指标有什么 花都小程序软件开发排名 学生信息网络安全提案 宝山区网络软件开发定制要求 实施的网络安全法是为了 哈理工网络技术部部长 吉林大学数据库视频 王思聪新服务器处理器价值13万 成都服务器报废选哪家 cgss卡牌数据库 mysql数据库考试题型 网络安全法文件 行为管理网关和服务器连接不上 服务器不刷 大华监控服务器登陆 云教互联网科技 网络安全股票怎么看 数据库 暗黑2 党妹服务器 安庆定制软件开发 git到自己的服务器 服务器的硬盘怎么没了 计算机网络技术三大结构 行为管理网关和服务器连接不上 龙之神途最好玩服务器