ios中微信内iframe页面,长按图片不出识别二维码功能

本文介绍了解决iOS微信内部iframe页面中长按图片无法识别二维码的问题。通过使用postMessage进行父子页面间的跨域通信,并在父页面上显示一个透明的二维码覆盖在图片上,从而实现长按识别功能。
2.ios中微信内iframe页面,长按图片不出识别二维码功能

解决办法:
用 postMessage处理两个页面的跨域问题:https://www.cnblogs.com/roam/p/7520433.html
在长按iframe中的二维码图片时,在父级页面生成一个二维码盖在上面。

iframe页面

    $('#erweima').on('touchstart',function(){
        window.parent.postMessage(JSON.stringify({state:1,url:'图片链接'}), '*');
    }).on('touchend',function(){
        window.parent.postMessage(JSON.stringify({state:2}), '*');
    })

父页面

    window.addEventListener('message', function(e) {
      let data = e.data
      if(typeof data == 'string'){
        data = JSON.parse(data)
      }
      if(data.state=='1'){//显示二维码
        that.showMa = true;
        that.erweimaUrl = data.url
      }else{//隐藏二维码
        that.showMa = false
      }
    }, false);

这里有个坑,父页面的二维码图片,需要做透明处理,经试验,如果设置opacity:0,则唤不起扫二维码的功能。故将其设为足够小的值,即可

opacity:0.01;

https://segmentfault.com/q/1010000008623366

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值