vue实现文字水印效果

2023-11-16

  • .vue文件代码

    <template>
        <div>
            <div class="watermark" ref="content"></div>
        </div>
    </template>
    <script>
    import watermark from './config/watermark'
    export default {
        mounted(){
            watermark.set("文字水印",this.$refs.content)
        },
        beforeDestroy(){
            watermark.set("",this.$refs.content)
        },
    }
    </script>
    <style lang="less" scoped>
        .watermark{
            width:1000px;
            height:600px;
            margin: 0 auto;
        }
    </style>
    
  • js文件代码

    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 = 200; //设置水印之间的左右间距
        can.height = 150; //设置水印之间的上下间距
    
        let cans = can.getContext("2d");
        cans.rotate((-20 * Math.PI) / 180);
        cans.font = "20px 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.className = "watermarkClass";
        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) => {
        const domArr = Array.from(document.getElementsByClassName("watermarkClass"));
        for (let i = 0; i < domArr.length; i++) {
            const element = domArr[i];
            // element.parentNode.removeChild(element);
            element.remove();
        }
        if (text == "") {
            return;
        }
        setWatermark(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;
    
    
  • 实现效果
    在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

vue实现文字水印效果 的相关文章

随机推荐

  • 飞旭体质健康测试云平台学生体质测试管理系统

    飞旭体测数据管理云平台是由体测设备 微信小程序和云平台构成 用户通过设备测试后 数据传输至云端 由云平台对数据进行针对性的统计分析 平台功能包括管理员分级管理 学生体质测试 学生体质测试成绩查询 测试数据管理统计分析 数据上报管理等内容 具
  • 15 周带你学好大一C语言!最详细C语言学习路线

    要学习 C 语言的读者抓紧时间看一下 我按照C语言学习视频的目录整理了一条以 周为单位时间 的学习路线 希望在开学后能按照这个进度去学习一遍 有要学习 C 语言的读者也可以参照 可能有些知识学习起来比较困难 比如说二进制这种涉及到底层方面的
  • iperf linux移植

    参考链接 1 iperf的git地址 windows版下载地址 git clone https github com esnet iperf git 2 下载到ubuntu上 3 找到交叉工具包的位置 opt arm ca9 linux g
  • 绘制复杂的层次的原理图

    一 绘制总体的区域块模块 1 新建一个PCB项目 在new中的project选择PCB 2 在项目中新建一个sheet文件 schemetic 然后找到place中的sheet Symbol Actions 3 修改每一个绿块的名称和文件名
  • 阻止移动端 touchmove 与 scroll 事件冲突

    在移动端开发过程中 如果要实现一个元素或按钮的拖动定位 会出现很多坑 例如 元素上下移动过程中 会触发 body 的 scroll 事件 导致整体的位置偏移 这时就需要 阻止移动端 touchmove 与 scroll 事件冲突 一 解决思
  • 【致敬未来的攻城狮计划】--RA2E1 开发板测评(3)按键输入

    前言 1 首先感谢 李肯前辈的活动 从而申请到了RA2L1开发板的测评 2 本文主要介绍按键输入的内容 3 学习本文需要准备的前提 致敬未来的攻城狮计划 RA2E1 开发板测评 1 keil环境配置 致敬未来的攻城狮计划 RA2L1 开发板
  • 自助Linux之问题诊断工具strace

    引言 Oops 系统挂死了 Oops 程序崩溃了 Oops 命令执行报错 对于维护人员来说 这样的悲剧每天都在上演 理想情况下 系统或应用程序的错误日志提供了足够全面的信息 通过查看相关日志 维护人员就能很快地定位出问题发生的原因 但现实情
  • 去除li前面小点点

    li list style type none
  • 3. 性能测试之目标评估

    文章目录 前言 一 模型1 根据日活计算目标QPS 1 原则 2 事例 二 模型2 根据压测数据评估最大支撑并发 1 原则 2 事例 3 备注 三 模型3 根据压测数据评估服务器资源 1 策略 2 备注 四 模型4 评估用户并发或峰值并发
  • Excel·VBA螺旋数组函数

    目录 1 由外到内顺时针的螺旋数组 实现方法1 代码思路 螺旋数组函数代码 举例 实现方法2 代码思路 螺旋数组函数代码 2 由外到内逆时针的螺旋数组 举例 数字1 12从左上角顺时针依次输出的即为螺旋数组 如下图 1 由外到内顺时针的螺旋
  • 网络编程3——TCP Socket实现的客户端服务器通信完整代码(详细注释帮你快速理解)

    文章目录 前言 一 理论准备 Socket套接字是什么 TCP协议的特点 二 TCP 流套接字提供的API ServerSocket API Socket API 三 代码实现请求响应式 客户端服务器 服务器 客户端 疑惑解答 为什么服务器
  • 获取Android设备唯一标识码

    概述 有时需要对用户设备进行标识 所以希望能够得到一个稳定可靠并且唯一的识别码 虽然Android系统中提供了这样设备识别码 但是由于Android系统版本 厂商定制系统中的Bug等限制 稳定性和唯一性并不理想 而通过其他硬件信息标识也因为
  • Simulink代码生成(二)——代码生成时模型的配置方法及操作流程

    Simulink代码生成 二 代码生成时模型的配置方法及操作流程 文章目录 Simulink代码生成 二 代码生成时模型的配置方法及操作流程 一 模型 二 代码生成设置 1 步长选择 2 系统目标文件设置 3 生成代码打开测试报告 4 保存
  • 为什么如今这么多人讨论网络安全?

    网络安全如今备受讨论 跟各种经济政治的关系是分不开的 并且变得更加复杂多变 网络安全的发展前景更可观 很多安全企业也开始积极寻求各类网络风险的防范方案和数据隐私保护技术 当今世界形势的变化 以及各种因素的不断影响 全球网络安全问题再不断提升
  • Qt扫盲-QSS概述

    QSS概述 一 概述 二 详细 一 概述 QSS 其实是Qt样式表 Qt样式表是Qt界面的一种强大的机制 除了通过继承QStyle已经可以实现的功能外 它还允许您自定义窗口组件的外观 Qt样式表的概念 术语和语法很大程度上受到HTML层叠样
  • sql server 提取汉字、数字和字母的sql server方法

    sql server 提取汉字 数字 字母的方法 提取数字 if object id dbo get number2 is not null drop function dbo get number2 go create function
  • QT学习(五)——从子窗口传来多个信号(带参数的自定义信号)

    同样是两个窗口 主窗口与副窗口 给副窗口自定义两个重载的信号 传给主窗口处理 void mySignals 信号可以重载 void mySignals int QString 由被关联的按钮发送消息 并送出两条消息给主窗口 emit myS
  • 常用C语言文件操作

    1 fopen 使用fopen需要引用头文件stdio h 函数声明如下 FILE fopen const char pathname const char mode 这里要多多关心的是第二个参数mode 关系到我们对文件操作的权限 这里做
  • 提升KNN的运行效率

    20221005 引言 KNN算法是一种 懒惰 算法 在模型训练过程 仅仅是将数据存储到快速查询的数据结构中 在测试阶段会通过进行距离计算来输出结果 那么当数据集比较大的时候 一方面内存要求会提升 另一方面在计算的时间也会增大 之前的时候
  • vue实现文字水印效果

    vue文件代码