由于开发需求需要在附件查看页面添加水印,于是网上看到一位大牛写了一个js加水印的方法觉得很实用,也很方便,记录一下,哈哈
大牛的博客链接:https://www.cnblogs.com/daixinyu/p/6715398.html 提供给大家学习
我优化了几点
1,我把水印的样式单独提出来,这样会提高渲染水印的性能
2,他是给整个页面添加水印,我修改一下是给需要添加水印的容器来加水印
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | function watermark(settings) { //默认设置 var defaultSettings={ watermark_txt: "text" , watermark_x:20, //水印起始位置x轴坐标 watermark_y:20, //水印起始位置Y轴坐标 watermark_rows:20, //水印行数 watermark_cols:20, //水印列数 watermark_x_space:100, //水印x轴间隔 watermark_y_space:50, //水印y轴间隔 watermark_width:210, //水印宽度 watermark_height:80, //水印长度 }; //采用配置项替换默认值,作用类似jquery.extend if (arguments.length===1&& typeof arguments[0] === "object" ){ var src=arguments[0]||{}; for (key in src){ if (src[key]&&defaultSettings[key]&&src[key]===defaultSettings[key]) continue ; else if (src[key]) defaultSettings[key]=src[key]; } } // 获取需要添加水印的容器 var box = document.getElementById( "box" ); // 创建水印容器 mark-box var markBox= document.createElement( 'div' ); markBox.className= "mark-box" ; //获取容器宽度 var page_width = box.offsetWidth; //获取页面最大高度 var page_height = box.offsetHeight; //如果将水印列数设置为0,或水印列数设置过大,超过页面最大宽度,则重新计算水印列数和水印x轴间隔 if (defaultSettings.watermark_cols == 0 || (parseInt(defaultSettings.watermark_x + defaultSettings.watermark_width *defaultSettings.watermark_cols + defaultSettings.watermark_x_space * (defaultSettings.watermark_cols - 1)) > page_width)) { defaultSettings.watermark_cols = parseInt((page_width-defaultSettings.watermark_x+defaultSettings.watermark_x_space) / (defaultSettings.watermark_width + defaultSettings.watermark_x_space)); defaultSettings.watermark_x_space = parseInt((page_width - defaultSettings.watermark_x - defaultSettings.watermark_width * defaultSettings.watermark_cols) / (defaultSettings.watermark_cols - 1)); } //如果将水印行数设置为0,或水印行数设置过大,超过页面最大长度,则重新计算水印行数和水印y轴间隔 if (defaultSettings.watermark_rows == 0 || (parseInt(defaultSettings.watermark_y + defaultSettings.watermark_height * defaultSettings.watermark_rows + defaultSettings.watermark_y_space * (defaultSettings.watermark_rows - 1)) > page_height)) { defaultSettings.watermark_rows = parseInt((defaultSettings.watermark_y_space + page_height - defaultSettings.watermark_y) / (defaultSettings.watermark_height + defaultSettings.watermark_y_space)); defaultSettings.watermark_y_space = parseInt(((page_height - defaultSettings.watermark_y) - defaultSettings.watermark_height * defaultSettings.watermark_rows) / (defaultSettings.watermark_rows - 1)); } var x; var y; for ( var i = 0; i < defaultSettings.watermark_rows; i++) { y = defaultSettings.watermark_y + (defaultSettings.watermark_y_space + defaultSettings.watermark_height) * i; for ( var j = 0; j < defaultSettings.watermark_cols; j++) { x = defaultSettings.watermark_x + (defaultSettings.watermark_width + defaultSettings.watermark_x_space) * j; var mask_div = document.createElement( 'div' ); mask_div.id = 'mask_div' + i + j; mask_div.className = 'mask_div' ; mask_div.appendChild(document.createTextNode(defaultSettings.watermark_txt)); //给水印定位 mask_div.style.left = x + 'px' ; mask_div.style.top = y + 'px' ; markBox.appendChild(mask_div); }; }; box.appendChild(markBox); } |
下面是水印样式
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | .mask_div { position : absolute ; overflow : hidden ; z-index : 9999 ; opacity: 0.2 ; pointer-events: none ; filter: alpha(opacity= 20 ); font-size : 18px ; font-family : 微软雅黑; color : rgb ( 170 , 170 , 170 ); text-align : center ; width : 210px ; height : 80px ; display : block ; -webkit-transform: rotate( -15 deg); -moz-transform: rotate( -15 deg); -ms-transform: rotate( -15 deg); -o-transform: rotate( -15 deg); transform: rotate( -15 deg); } |
调用方法watermark({options})
分类:
JavaScript
标签:
js水印
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!