vue 微信公众号 二维码 ios系统长按没有反应,识别不了二维码

本文介绍了解决iOS设备上长按识别二维码无反应的问题,通过调整项目结构,将二维码置于新页面并添加特定CSS样式,成功实现了长按识别功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在做项目,有一个需要长按二维码,直接识别二维码来关注公众号,写好以后,安卓手机可以使用,但是苹果手机长按没有一点反应,就去查找解决方法,找了很多,有说

1、是存放二维码的页面,不要放多个;

2、还有是说,放二维码的页面不能有position:fixed(固定定位);

3、是index.html页面meta缩放问题了;

4、什么history模式了;

5、什么在img父元素div加背景二维码图片了

以上这些方法,除了第二种,其他都已经尝试,没有达到效果。

我的项目是,父组件里面调用了子组件,子组件里面有二维码,父组件使用了fixed定位。

所以我的调整方法是,在二维码那里设置点击事件,跳转到新页面,新页面防置二维码以及一些信息,这样实现的效果是点击有反应了,页面内容如下:

代码如下:

1、父组件里面的点击事件:

2、新的关注页面代码:

<div class="goal__content-body">
          {{usText}}
          <p>如想关注公众号,请长按二维码:</p>
        </div>
        <img :src="src" class="img_info"/>

3、src路径:

以上就是响应的代码,不过这样还有一个问题就是,长按二维码会放大,并且出现分享、等操作,就需要给img图片加一个css样式:

-webkit-touch-callout: none;

如下图:

这样就么有问题了~  结果如下:

成功啦~~ 

UniApp是一个基于Vue.js的跨平台框架,它允许开发者编写一次代码,生成iOS、Android、Web等多端应用。在微信小程序中,虽然原生不支持直接提供按图片识别二维码的功能,但你可以通过集成第三方库或者自定义组件的方式来实现这个需求。 一种常见的做法是使用JavaScript API来模拟按事件,然后调用微信JSSDK中的`scanCodeScanner`接口,让用户手动触发扫描二维码的过程。例如,你可以创建一个自定义组件,当用户按时显示提示,并调用扫码功能: ```html <template> <view class="custom-image" @touchstart="onTouchStart" @touchend="onTouchEnd"> <image :src="imageUrl" /> </view> </template> <script> import wx from '@ uni-app/core/util/wx'; export default { methods: { onTouchStart(e) { this.showScanPrompt(); }, onTouchEnd(e) { // 如果用户松开手指,取消扫描提示并开始扫描 this.hideScanPrompt(); wx.scanCode({ needResult: 'auto', // 默认为自动检测是否扫描成功 scanType: ['qrCode', 'barCode'], // 可以同时扫二维码和条形码 success(res) { console.log('扫码结果:', res.resultStr); // 打印扫描到的二维码内容 } }); }, showScanPrompt() { // 显示扫描提示 }, hideScanPrompt() { // 隐藏扫描提示 }, }, data() { return { imageUrl: 'your_image_url' }; } }; </script> ``` 请注意,你需要先在小程序管理后台配置相应的JSAPI权限。同时,由于微信小程序的隐私政策限制,这种方式并不适用于直接在页面上识别,通常建议引导用户去其他地方完成扫描操作,如点击一个按钮跳转至新的界面。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值