vue微信H5长按无法弹出识别二维码

42 篇文章 0 订阅
4 篇文章 1 订阅

一、场景

使用vue写了一个H5项目,然后在IOS微信公众号里可以长按识别二维码,以便用户关注,但是发现在微信公众号无法弹出识别。

vue的路由是默认的:hash。

二、查找原因

网上搜索了很多方案,修改样式、尺寸大小、甚至加上logo,都是无法成功。

如果单独的写一个静态页面,放一张图片,然后在微信公众号里是可以识别。

但是只要在vue搭建的项目里,就是无法访问,就单独放一个图片也不行。

三、解决方案

只能就把两张页面进行对比,把vue的页面复制到html的另一个页面,然后再一点点删除怀疑的地方,脚本文件等,终于找到可疑的文件:css文件。

那就看看是哪个属性导致的,最终看到了一个全局变量img属性:-webkit-touch-callout : none;

-webkit-touch-callout 是一个 不规范的属性(unsupported WebKit property),它没有出现在 CSS 规范草案中。当你触摸并按住触摸目标时候,禁止或显示系统默认菜单。在iOS上,当你触摸并按住触摸的目标,比如一个链接,Safari浏览器将显示链接有关的系统默认菜单。这个属性可以让你禁用系统默认菜单。

把这个属性去掉即可实现长按识别二维码。

可能前端考虑的因素比较多,所以就写了一个公共的样式。

 

 

 

 

 

 

以下是Vue微信H5分享的代码示例: ```javascript export default { data() { return { shareTitle: '分享标题', shareDesc: '分享描述', shareLink: window.location.href, shareImgUrl: '分享图标url' } }, mounted() { this.initWechatShare() }, methods: { initWechatShare() { // 引入微信JS-SDK const wx = require('weixin-js-sdk') const url = window.location.href.split('#')[0] const data = { url } // 向后端请求签名数据 axios.get('/api/wechat/signature', { params: data }).then(res => { if (res.data.code === 0) { const signatureData = res.data.data wx.config({ debug: false, appId: signatureData.appId, timestamp: signatureData.timestamp, nonceStr: signatureData.nonceStr, signature: signatureData.signature, jsApiList: [ 'updateAppMessageShareData', 'updateTimelineShareData' ] }) wx.ready(() => { // 分享到朋友圈 wx.updateTimelineShareData({ title: this.shareTitle, // 分享标题 link: this.shareLink, // 分享链接 imgUrl: this.shareImgUrl, // 分享图标 success() { // 分享成功回调 } }) // 分享给朋友 wx.updateAppMessageShareData({ title: this.shareTitle, // 分享标题 desc: this.shareDesc, // 分享描述 link: this.shareLink, // 分享链接 imgUrl: this.shareImgUrl, // 分享图标 type: '', // 分享类型,music、video或link,不填默认为link dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空 success() { // 分享成功回调 } }) }) } }) } } } ``` 在以上代码中,我们使用 axios 向后端请求签名数据,获取 appId、timestamp、nonceStr 和 signature 等信息,然后使用微信 JS-SDK 进行配置和分享。分享到朋友圈使用的接口是 `wx.updateTimelineShareData`,分享给朋友使用的接口是 `wx.updateAppMessageShareData`。 注意,以上代码仅供参考,实际使用需要根据自己的情况进行修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

低调之人

略表心意,哈哈哈

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值