canvas 图片保存本地 复制到剪切板

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>

    <canvas id="canvas"></canvas></br>
    <button onclick="downloadLocalClick()">下载本地</button>
    <button onclick="duplicatingShearsClick()">复制到剪切板</button>

    <script>
      const canvas = document.getElementById("canvas");
      const context = canvas.getContext("2d");
      const img = new Image();
      img.onload = () => {
        canvas.width = img.width;
        canvas.height = img.height;
        context.drawImage(img, 0, 0);
      };
      img.crossOrigin = "";
      img.src =
        "https://img2.baidu.com/it/u=1492005040,3158981175&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500";

      //下载本地
      function downloadLocalClick() {
        let dataURL = canvas.toDataURL({ pixelRatio: 1 });
        let link = document.createElement("a");
        link.download = '图片名字.png'; //也可以写jpg 可以任意哦
        link.href = dataURL;
        document.body.appendChild(link);
        link.click();
        document.body.removeChild(link);
        link = "";

      }
      //复制到剪切板 
      async function duplicatingShearsClick() {
        let dataURL = canvas.toDataURL({ pixelRatio: 1 });
        const data = await fetch(dataURL);
        const blob = await data.blob();
        let ClipboardItem = window.ClipboardItem;
        await navigator.clipboard.write([
          new ClipboardItem({
            [blob.type]: blob,
          }),
        ]);
        alert('复制成功~~')
      }
    </script>
  </body>
</html>

注意:复制剪切板功能在本地环境、https环境可以使用,在http环境下不能使用,api限制

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值