前端技术图解(前端水印的简单实现代码示例)
类别:Web前端 浏览量:1978
时间:2021-10-22 07:16:25 前端技术图解
前端水印的简单实现代码示例前言
前端实现的水印基本都是不安全的,可被破解的~.~
水印
水印(watermark)是一种容易识别、被夹于纸内,能够透过光线穿过从而显现出各种不同阴影的技术。
实现
先创建一个 wrap 块,并给其设置一些样式:
<li class="wrap1 wrap_common"></li> <style> * { margin: 0; padding: 0; } .wrap_common { position: relative; margin: 0 auto; width: 800px; height: 44vh; border: 1px solid rgba(0, 0, 0, 1); background: rgba(255, 255, 255, 1); overflow: hidden; } .wrap_common:first-child{ margin-bottom: 5vh; } </style>
1. li绝对定位
通过图层叠加的方式将水印追加到 wrap 上,我们先看一下最终效果
动态获取到 wrap 的长宽并计算其能放几个水印块,并相应的设置每一个水印块的偏移值 left,top即可:
const wrap = document.querySelector('.wrap1'); const { clientWidth, clientHeight } = wrap; const waterHeight = 100; const waterWidth = 180; // 能放下几行几列 const [columns, rows] = [Math.ceil(clientWidth / waterWidth), Math.ceil(clientHeight / waterHeight)] for (let i = 0; i < columns; i++) { for (let j = 0; j <= rows; j++) { // 生成水印块 const watcerMarkElement = createWaterMarkElement(); // 动态设置偏移值 addAttributes(watcerMarkElement, { width: `${waterWidth}px` , height: `${waterHeight}px` , left: `${waterWidth + (i - 1) * waterWidth + 10}px` , top: `${waterHeight + (j - 1) * waterHeight + 10}px` , }); wrap.appendChild(watcerMarkElement) } }
2. canvas+背景图
我们知道,可以给 li 设置样式 background,我们可以很轻松的实现背景图片,那么水印也可以通过这种方式来实现,其中背景图片通过 canvas 画出来,并且通过 toDataURL() 将图片转为 dataURL(base64),最后追加到 background-image 样式中。
const wrap = document. querySelector('. wrap2'); wrap.style.backgroundImage = `url(${drawWaterMark()})` ;
drawWaterMark 方法实现如下 :
const drawWaterMark = (text = '小豪看世界') => { const sin = Math.sin(Math.PI / 4.5); const cos = Math.cos(Math.PI / 4.5); const canvas = document.createElement('canvas') canvas.width = 200; canvas.height = 100; const ctx = canvas.getContext('2d'); ctx.transform(cos, -sin, sin, cos, 0, 0); ctx.font = '16px'; ctx.fillStyle = 'rgba(0,0,0,.4)'; ctx.fillText(text, 80, 140); ctx.fillText(text, -30, 100); return canvas.toDataURL('image.jpg" alt="前端技术图解(前端水印的简单实现代码示例)" border="0" />
我们可以看到 wrap 插入了一个 base64的图片,强迫症的童鞋可以处理一下,将它转为 style 标签插入到body中;
改为 style 标签插入:
const style = document. createElement('style'); style.type = 'text/css'; style.innerHTML = ` .wrap2 { background-image: url(${drawWaterMark()}); } `; document.body.appendChild(style);
emmm,看起来美观一点了~.~
参考
从破解某设计网站谈前端水印(详细教程)
源码
源码
到此这篇关于前端水印的简单实现代码示例的文章就介绍到这了,更多相关前端水印内容请搜索开心学习网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持开心学习网!
您可能感兴趣
- canvas怎么获取内容(详解canvas.toDataURL报错的解决方案全都在这了)
- jscanvas画折线图(js+canvas实现代码雨效果)
- html5中canvas标签(html5 canvas绘制网络字体的常用方法)
- canvas 裁剪画布(Canvas图片分割效果的实现)
- html5的canvas图形绘制技术(导出HTML5 Canvas图片并上传服务器功能)
- canvas 缩放后字发虚(canvas 绘图时位置偏离的问题解决)
- canvas绘制图像文件方法(Canvas多边形绘制的实现方法)
- canvas设置点击(Canvas高级路径操作之拖拽对象的实现)
- canvas绘制流星(使用canvas实现黑客帝国数字雨效果)
- canvas指定区域生成图片(canvas实现图片镜像翻转的2种方式)
- html5canvas曲线图例子(html5利用canvas实现颜色容差抠图功能)
- canvas小程序海报(使用canvas生成含有微信头像的邀请海报没有微信头像问题)
- canvas处理图片风格(html2 canvas生成清晰的图片实现打印功能)
- canvas 绘图解决方案(高清屏下canvas重置尺寸引发的问题的解决)
- canvas如何调试(关于canvas.toDataURL 在iOS运行失败的问题解决)
- html5的canvas图形绘制技术(详解HTML5 Canvas标签及基本使用)
- 前《iLOOK》时装总监 《快乐大本营》御用造型师上线(快乐大本营御用造型师上线)
- 释小龙晒杀青照片 多重身份惹观众期待(释小龙晒杀青照片)
- 《九牛之人降魔传》开机 演员祁高坤化身九牛之人除魔卫道(九牛之人降魔传开机)
- 王铲铲的致富之路无限金币卡法攻略教学(王铲铲的致富之路无限金币卡法攻略教学)
- 文明6金币太少怎么办 文明6无限刷钱教程(文明6金币太少怎么办)
- 开国中将,王牌军63军首任政委,两个连襟一个上将一个少将传为佳话(王牌军63军首任政委)
热门推荐
- thinkphp前后端配合(thinkPHP+LayUI 流加载实现功能)
- HTML5<q> 与 <blockquote> 的区别
- 宝塔面板怎么修改内容(宝塔面板如何关闭日志)
- nginx proxy设置存放在哪里(nginx配置proxy_pass中url末尾带/与不带/的区别详解)
- svg怎么在html中显示(html svg生成环形进度条的实现方法)
- dede后台建栏目(DedeEIMS后台栏目模板含单独页模板修改方法)
- phpstudy显示403(phpStudy配置多站点多域名方法及遇到的403错误解决方法)
- mysql order by id查询变慢(MySQL不使用order by实现排名的三种思路总结)
- python零基础入门加密与解密(Python玩转加密的技巧推荐)
- appui代码(AmazeUI 图标的示例代码)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9