HTML 添加 文本水印

    body,html {margin: 0;height: 100vh;width: 100vw;}
// 自定义文案const setting = {text: "水印文案", // 水印内容innerDate: true, // 在水印下方增加日期width: 110, // 水印宽度};// 自定义文字水印const watermark = (function () {return {build: function (arg) {// 获取页面宽度let maxWidth =Math.max(document.body.scrollWidth, window.screen.width) - 20;// 获取页面高度let maxHeight =Math.max(document.body.scrollHeight, document.body.clientHeight) +100;if (maxHeight === 0) {console.info("该页面无需水印");return;}const setting = {text: "水印 水印 水印", // 默认水印内容beginX: 50, // 默认起始x坐标endX: 0, // 默认结束x坐标beginY: 50, // 默认起始y坐标endY: 0, // 默认结束y坐标intervalX: 150, // 默认横向间隔宽度intervalY: 100, // 默认纵向间隔高度opacity: 0.3, // 字体透明度angle: 20, // 字体倾斜度fontsize: "15px", // 字体大小fontFamily: "微软雅黑", // 字体width: 100, // 水印(每个)宽度height: 80, // 水印(每个)高度innerDate: false, // 是否附带日期};// 默认变量与自定义变量结合if (arguments.length === 1 && typeof arguments[0] === "object") {const src = arguments[0] || {};for (const key in src) {if (!src.hasOwnProperty(key) || !src[key]) {continue;}for (const def in setting) {if (key === def) {setting[def] = src[key];}}}}// 计算列个数const cols = parseInt((setting.intervalX + maxWidth - setting.beginX - setting.endX) /(setting.width + setting.intervalX) +"");// 计算行个数const rows = parseInt((setting.intervalY + maxHeight - setting.beginY - setting.endY) /(setting.height + setting.intervalY) +"");// 水印内容附加日期if (setting.innerDate) {const date = new Date();setting.text = [setting.text,"<br>",date.getFullYear(),"年",date.getMonth() + 1,"月",date.getDate(),"日",].join("");}const fragment = document.createDocumentFragment();let x, y;for (let i = 0; i < rows; i++) {y = setting.beginY + (setting.intervalY + setting.height) * i;for (let j = 0; j < cols; j++) {x = setting.beginX + (setting.width + setting.intervalX) * j;const element = document.createElement("div");element.id = "watermark" + i + j;// 设置倾斜角element.style.MozTransform ="rotate(-" + setting.angle + "deg)";element.style.msTransform = "rotate(-" + setting.angle + "deg)";element.style.OTransform = "rotate(-" + setting.angle + "deg)";element.style.transform = "rotate(-" + setting.angle + "deg)";element.style.position = "absolute";element.style.left = x + "px";element.style.top = y + "px";element.style.overflow = "hidden";element.style.zIndex = "9999";element.style.pointerEvents = "none";element.style.opacity = setting.opacity;element.style.fontSize = setting.fontsize;element.style.fontFamily = setting.fontFamily;element.style.color = "#aaa";element.style.textAlign = "center";element.style.width = setting.width + "px";element.style.height = setting.height + "px";element.style.display = "block";element.innerHTML = setting.text;fragment.appendChild(element);}}document.body.appendChild(fragment);},};})();watermark.build(setting);

超链接:图片水印

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/483993.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机的错误计算(一百七十四)

摘要 探讨 MATLAB 关于计算机的错误计算&#xff08;一百七十三&#xff09;中多项式的秦九韶&#xff08;或Horner&#xff09;形式的计算误差。 在计算机的错误计算&#xff08;一百七十三&#xff09;中&#xff0c;我们讨论了一个多项式的计算误差。本节探讨其对应秦九韶&…

扩展 SOC 的能力以应对更多威胁

过去 18 个月中&#xff0c;安全运营的一个主要趋势是注重“用更少的资源做更多的事情”。这种趋势一直延续到今天&#xff0c;尽管这一挑战并非安全领域独有——许多其他技术子领域也感受到了同样的压力——但安全领域可能是最不能有效吸收这种额外工作量的领域。 Exabeam 和…

堆叠的简析

堆叠 堆叠的概念 堆叠是指将一台以上的交换机组合起来共同工作&#xff0c;以便在有限的空间内提供尽可能多的端口。‌ 堆叠技术可以通过专用连接电缆将多台交换机连接成一个堆叠单元&#xff0c;从而增加端口密度和管理效率。‌12 堆叠与级联有所不同。级联的交换机之间可以…

vulnhub靶场之momentum-2

前言 靶机采用virtual box虚拟机&#xff0c;桥接网卡 攻击采用VMware虚拟机&#xff0c;桥接网卡 靶机&#xff1a;momentum-2 192.168.1.40 攻击&#xff1a;kali 192.168.1.16 主机发现 使用arp-scan -l扫描 信息收集 使用namp扫描 这里的命令对目标进行vulner中的漏…

【Elasticsearch】实现分布式系统日志高效追踪

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家&#xff0c;历代文学网&#xff08;PC端可以访问&#xff1a;https://literature.sinhy.com/#/literature?__c1000&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;…

【0x3D】HCI_Remote_Host_Supported_Features_Notification事件详解

目录 一、事件概述 二、事件格式及参数说明 2.1. HCI_Remote_Host_Supported_Features_Notification事件格式 2.2. BD_ADDR 2.3. Remote_Host_Supported_Features 三、事件作用 3.1. 设备特性沟通与理解 3.2. 功能协商与性能优化 3.3. 设备管理与配置更新 四、应用场…

【C++】栈和队列的模拟实现(适配器模式)

不论是C语言还是C&#xff0c;我们都用其对应的传统写法对栈和队列进行了模拟实现&#xff0c;现在我们要用新的方法模拟实现栈和队列&#xff0c;这个新方法就是适配器模式。 C语言传统写法&#xff1a; C语言模拟实现栈 C传统写法&#xff1a;C模拟实现栈 1.容器适配器 …

【工具变量】上市公司企业所在地城市等级直辖市、副省级城市、省会城市 计划单列市(2005-2022年)

一、包含指标&#xff1a; 股票代码 股票代码 股票简称 年份 所属城市 直辖市&#xff1a;企业所在地是否属于直辖市。1是&#xff0c;0否。 副省级城市&#xff1a;企业所在地是否属于副省级城市。1是&#xff0c;0否。 省会城市&a…

【HarmonyOS】鸿蒙应用地理位置获取,地理名称获取

【HarmonyOS】鸿蒙应用地理位置获取&#xff0c;地理名称获取 一、前言 首先要理解地理专有名词&#xff0c;当我们从系统获取地理位置&#xff0c;一般会拿到地理坐标&#xff0c;是一串数字&#xff0c;并不是地理位置名称。例如 116.2305&#xff0c;33.568。 这些数字坐…

【优选算法篇】寻找隐藏的宝藏:用二分查找打开算法世界的大门(上篇)

文章目录 须知 &#x1f4ac; 欢迎讨论&#xff1a;如果你在学习过程中有任何问题或想法&#xff0c;欢迎在评论区留言&#xff0c;我们一起交流学习。你的支持是我继续创作的动力&#xff01; &#x1f44d; 点赞、收藏与分享&#xff1a;觉得这篇文章对你有帮助吗&#xff1…

【后端面试总结】golang channel深入理解

在Go语言中&#xff0c;Channel是一种用于在goroutine之间进行通信和同步的重要机制。它提供了一种安全、类型安全的方式来传递数据&#xff0c;使得并发编程变得更加直观和简单。本文将详细介绍Golang中Channel的基本概念、创建与关闭、发送与接收操作&#xff0c;以及相关的使…

centos 手动安装libcurl4-openssl-dev库

下载源代码 curl downloadshttps://curl.se/download/ 选择需要下载的版本&#xff0c;我下载的是8.11.0 解压 tar -zxvf curl-8.11.0 查看安装命令 查找INSTALL.md&#xff0c;一般在docs文件夹下 –prefix &#xff1a;指定安装路径&#xff08;默认安装在/usr/local&…

基于TensorFlow框架的线性回归实现

目录 ​编辑 线性回归简介 TensorFlow简介 线性回归模型的TensorFlow实现 1. 安装TensorFlow 2. 导入必要的库 3. 准备数据 4. 定义模型 5. 定义损失函数 6. 定义优化器 7. 训练模型 8. 评估模型 9. 模型参数的可视化 10. 模型预测的准确性评估 结论 在统计学和…

40分钟学 Go 语言高并发:服务性能调优实战

服务性能调优实战 一、性能优化实战概述 优化阶段主要内容关键指标重要程度瓶颈定位收集性能指标&#xff0c;确定瓶颈位置CPU、内存、延迟、吞吐量⭐⭐⭐⭐⭐代码优化优化算法、并发、内存使用代码执行时间、内存分配⭐⭐⭐⭐⭐系统调优调整系统参数、资源配置系统资源利用率…

云计算vsphere 服务器上添加主机配置

这里是esxi 主机 先把主机打开 然后 先开启dns 再开启 vcenter 把每台设备桌面再vmware workstation 上显示 同上也是一样 &#xff0c;因为在esxi 主机的界面可能有些东西不好操作 我们选择主机和集群 左边显示172.16.100.200

使用PaddlePaddle实现线性回归模型

目录 ​编辑 引言 PaddlePaddle简介 线性回归模型的构建 1. 准备数据 2. 定义模型 3. 准备数据加载器 4. 定义损失函数和优化器 5. 训练模型 6. 评估模型 7. 预测 结论 引言 线性回归是统计学和机器学习中一个经典的算法&#xff0c;用于预测一个因变量&#xff0…

将word里自带公式编辑器编辑的公式转换成用mathtype编辑的格式

文章目录 将word里自带公式编辑器编辑的公式转换成用mathtype编辑的格式MathType安装问题MathType30天试用延期MathPage.wll文件找不到问题 将word里自带公式编辑器编辑的公式转换成用mathtype编辑的格式 word自带公式编辑器编辑的公式格式&#xff1a; MathType编辑的格式&a…

一文说清:Git创建仓库的方法

0 引言 本文介绍如何创建一个 Git 本地仓库&#xff0c;以及与远程仓库的关联。 1 初始化仓库&#xff08;git init&#xff09; 1.1 概述 Git 使用 git init 命令来初始化一个 Git 仓库&#xff0c;Git 的很多命令都需要在 Git 的仓库中运行&#xff0c;所以 git init 是使…

【Linux系统编程】——理解冯诺依曼体系结构

文章目录 冯诺依曼体系结构硬件当代计算机是性价比的产物冯诺依曼的存储冯诺依曼的数据流动步骤冯诺依曼结构总结 冯诺依曼体系结构硬件 下面是整个冯诺依曼体系结构 冯诺依曼结构&#xff08;Von Neumann Architecture&#xff09;是现代计算机的基本结构之一&#xff0c;由数…

一、docker简介

一、docker简介 1.1 docker的前世今生 Docker是基于Go语言实现的开源容器项目&#xff0c;诞生于2013年年初&#xff0c;最初的发起者是dotCloud公司&#xff0c;Docker自开源后受到广泛的关注和讨论&#xff0c;目前已有多个相关项目&#xff08;包括Docker三剑客、Kubernet…