html2canvas页面生成图片并添加水印

安装:yarn add html2canvas

引用:

import html2canvas from 'html2canvas';

使用:

 //导出图片
            printOut(name) {
                let dom = document.querySelector('#main');
                let img = document.querySelector('#watermark');
                html2canvas(dom, {
                    useCORS: true, //支持图片跨域
                    scale: 1, //设置放大的倍数
            // 页面有滚动条时设置,若不加导出图片为当前可视区域 height: document.getElementById('main').scrollHeight, windowHeight: document.getElementById('main').scrollHeight, backgroundColor:null }).then((canvas) => {
            //添加水印 let ctx = canvas.getContext("2d"); const water = document.createElement('canvas'); water.width=260; water.height=300; const waterCtx = water.getContext("2d"); waterCtx.drawImage(img, 30, 60); const pat = ctx.createPattern(water,'repeat'); ctx.fillStyle=pat; ctx.fillRect(0,0,canvas.width,canvas.height) // 生成图片导出 const a = document.createElement('a'); a.href = canvas.toDataURL('image/png'); a.download = name; a.click(); }) },

var img = new Image();

//引入图片地址

img.src = "img/watermark.jpg"

img.onload = function () {
var context = canvas.getContext("2d");
context.drawImage(img, 0, 0);
}

  此处水印是图片,使用图片地址(如上方式)一直不成功,所以使用了dom 的方式,添加在页面内隐藏

  大佬有解决方案的话,欢迎留言指正

posted @ 2022-02-21 18:22  lilyliu329  阅读(1419)  评论(0编辑  收藏  举报