VUE 移动端H5页面实现长按图片保存到手机功能

需求背景:

我们做的项目类似于支付二维码,让用户保存到手机可以去制作亚克力牌用来收钱。
效果图:
在这里插入图片描述

踩坑:

在网上查了好多方法,但是都没有用,脑袋秃秃,html5plus只适用于app项目跟小程序,大家一定要好好阅读官方文档呀,使用踩坑报错plus is undefined,然后又试错了好多种方法,最后成功实现,下面附上代码:

实现:
// 存放图片的div 长按
<div
   @touchstart="touchStart()"
   @touchend="touchEnd()"
>
   <img :src="qrcodeUrl" alt="">
</div>
data(){
	Loop:'', //  定时器 
	qrcodeUrl:'', // 后端返回的二维码图片路径
	qrcodeUrl64:'', //是后端返回二维码图片的二进制流
},
methods:{
	touchEnd() {
      //手指离开
      clearTimeout(this.Loop);
    },
    touchStart() {
      //手指触摸
      clearTimeout(this.Loop); //再次清空定时器,防止重复注册定时器
      this.Loop = setTimeout(() => {
        this.downloadIamge(this.qrcodeUrl64, "pic");
      }, 1000);
    },
     downloadIamge(imgsrc, name) {
      //下载图片地址和图片名
      var image = new Image();
      // 解决跨域 Canvas 污染问题
      image.setAttribute("crossOrigin", "anonymous");
      image.onload = function() {
        var canvas = document.createElement("canvas");
        canvas.width = image.width;
        canvas.height = image.height;
        var context = canvas.getContext("2d");
        context.drawImage(image, 0, 0, image.width, image.height);
        var url = canvas.toDataURL("image/png"); //得到图片的base64编码数据
        var a = document.createElement("a"); // 生成一个a元素
        var event = new MouseEvent("click"); // 创建一个单击事件
        a.download = name || "photo"; // 设置图片名称
        a.href = url; // 将生成的URL设置为a.href属性
        a.dispatchEvent(event); // 触发a的单击事件
      };
      image.src = imgsrc;
    },
}
结语

以上方法亲测有效,欢迎大家来踩~ :D

  • 14
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 8
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值