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;