【sgWatermark.js】自定义组件:基于Vue2+html2canvas实现全局水印效果

sgWatermark.js源码

javascript 复制代码
import html2canvas from 'html2canvas'; // npm install --save html2canvas (官网:https://html2canvas.hertzen.com)
export default {
  addWatermark({
    container = document.body, // 水印添加到的容器
    innerHTML = "水印文字内容", // 水印文字的内容
    rotate = -30,//默认文字旋转角度
    cssText = `
      box-sizing: border-box;
      width: max-content;
      height: max-content;
      padding: 30px;
      font-size: 12px;
      font-family: 'Microsoft YaHei';
      color: #00000022;
      transform-origin:center;
      transform: rotate(-30deg);
      z-index: 999999;
      pointer-events: none;
      display: flex;
      justify-content: center;
      align-items: center;
    `,//水印模板文本的默认样式
    className = '__sgWatermark__',//水印类名
  } = {}) {
    let dom = document.createElement("div");
    dom.innerHTML = innerHTML;
    dom.style.cssText = cssText;//默认样式
    dom.style.transform = `rotate(${rotate}deg)`;//旋转角度
    container.appendChild(dom);//添加模板文本
    // ----------------------------------------
    html2canvas(dom, { backgroundColor: 'transparent', logging: false, }).then(canvas => {
      dom.parentNode.removeChild(dom);//移除模板文本
      let base64Url = canvas.toDataURL('image/png', 1.0);
      const __sgWatermark__ = document.querySelector(`.${className}`);
      const watermarkDiv = __sgWatermark__ || document.createElement("div");
      watermarkDiv.style.cssText = `transition: .618s ease;opacity: 0;position: fixed; top: 0; left: 0; bottom: 0; right: 0; pointer-events: none; z-index: 999999999; background: url(${base64Url}); `;
      setTimeout(() => {
        watermarkDiv.style.opacity = 1;//缓慢出现
      }, 0);
      watermarkDiv.className = className;
      __sgWatermark__ || container.insertBefore(watermarkDiv, container.firstChild);
    });
  },
  removeWatermark(
    className = '__sgWatermark__',//水印类名
  ) {
    const dom = document.querySelector(`.${className}`);
    dom.parentNode.removeChild(dom);
  },
};

示例

html 复制代码
<template>
  <div :class="$options.name">
    <el-button type="primary" style="width: 300px; height: 100px">主要按钮</el-button>
    <div
      ref="div"
      style="
        width: 600px;
        height: 300px;
        background-color: #00000011;
        display: flex;
        justify-content: center;
        align-items: center;
      "
    >
      局部div
    </div>
  </div>
</template>
<script>
import sgWatermark from "@/js/sgWatermark";
export default {
  mounted() {
    // 示例1
    sgWatermark.addWatermark();
    // 示例2
    // sgWatermark.addWatermark({ container: this.$el, innerHTML: `高启强(No:201314)` });
    // 示例3
    // sgWatermark.addWatermark({ container: this.$refs.div, innerHTML: `<b style="color: #F56C6C88;font-weight: bold;font-size: 24px;" >你挚爱的强哥</b>` });
  },
};
</script>
相关推荐
kyriewen6 小时前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程
weedsfly9 小时前
迭代器、生成器与异步迭代——让数据“按需流动”的艺术
前端·javascript
假如让我当三天老蒯9 小时前
前端跨域解决方案(学习用)
前端·javascript·面试
铁皮饭盒11 小时前
Bun 哪比 Node.js 快?
javascript·后端
JieE21219 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
candyTong21 小时前
RTK 技术原理:一次典型会话里,80% 上下文是怎么省下来的
javascript·后端·架构
_柳青杨1 天前
深入理解 JavaScript 事件循环
前端·javascript
大家的林语冰1 天前
ES5 凉凉,Babel 8 正式发布,默认不再编译为 ES5 和 CJS......
前端·javascript·前端工程化
weedsfly1 天前
异步编程全景与事件循环——彻底搞懂 JS 执行机制
前端·javascript
用户1733598075371 天前
纯前端 PDF 数字签名实战:Vue 3 + pdf-lib 在浏览器里完成签名嵌入
前端·javascript