vue 頁面添加水印的方法


 

 1、創建一個watermark.js文件

let watermark = {}

let setWatermark = (str) => {
    let id = '1.23452384164.123412416';

    if (document.getElementById(id) !== null) {
        document.body.removeChild(document.getElementById(id));
    }

    //創建一個畫布
    let can = document.createElement('canvas');
    //設置畫布的長寬
    can.width = 220;
    can.height = 220;

    let cans = can.getContext('2d');
    //旋轉角度
    cans.rotate(-15 * Math.PI / 180);
    cans.font = '18px Vedana';
    //設置填充繪畫的顏色、漸變或者模式
    cans.fillStyle = 'rgba(200, 200, 200, 0.40)';
    //設置文本內容的當前對齊方式
    cans.textAlign = 'left';
    //設置在繪制文本時使用的當前文本基線
    cans.textBaseline = 'Middle';
    //在畫布上繪制填色的文本(輸出的文本,開始繪制文本的X坐標位置,開始繪制文本的Y坐標位置)
    cans.fillText(str, can.width / 8, can.height / 2);

    let div = document.createElement('div');
    div.id = id;
    div.style.pointerEvents = 'none';
    div.style.top = '30px';
    div.style.left = '0px';
    div.style.position = 'fixed';
    div.style.zIndex = '0';
    div.style.width = document.documentElement.clientWidth + 'px';
    div.style.height = document.documentElement.clientHeight + 'px';
    div.style.background = 'url(' + can.toDataURL('image/png') + ') left top repeat';
    document.body.appendChild(div);
    return id;
}

// 該方法只允許調用一次
watermark.set = (str) => {
    let id = setWatermark(str);
    setInterval(() => {
        if (document.getElementById(id) === null) {
            id = setWatermark(str);
        }
    }, 500);
    window.onresize = () => {
        setWatermark(str);
    };
}

export default watermark;

2、引用組件、調用方法

import watermark from "./watermark.js";
export default {
  data() {
   return:{}
  },
 
  mounted() {
    watermark.set("水印20220111");
  },
};
</script>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM