vue如何实现水印效果
发表于:2025-01-18 作者:千家信息网编辑
千家信息网最后更新 2025年01月18日,这篇文章给大家分享的是有关vue如何实现水印效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言:vue项目中使用水印效果,可指定容器效果图:1、不指定容器2、指定容器实
千家信息网最后更新 2025年01月18日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安全错误 数据库的锁怎样保障安全 互联网科技展文档 网络安全分析简答题 数据库系统核心和管理对象是 服务器安全狗怎么开启端口 数据库匹配的对象 服务器名链接 网络安全学院建设 数据库中间件技术引用文献 网络安全小讲师事迹 盛行时代网络安全吗 Oracle数据库嵌套模型 怎样升级数据库 神通数据库删除表空间 福建常见软件开发报价 真实项目数据库表设计 数据库中脏读的定义是什么 怎么通过手机进入联机侠服务器 未在一个战斗服务器 幼儿网络安全宣传画怎么画 c 数据库查询语句 服务器含不含电池 网络安全法手抄报图片 服务器为什么不能主动连接客户 软件开发技术要学多久 nod32国内服务器 如何监控数据库表是否变化 学软件开发可以去哪些公司 web服务器日志文件 4.1 软件开发环境介绍 数据库查询分页语句mysql