微信长按识别二维码 -- 页面多个二维码如何识别?

本文探讨了在公众号HTML页面中实现多个二维码长按识别的挑战,并提供了解决方案,确保每个二维码都能被准确识别。

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

常规的在公众号html页面中要实现长按识别二维码,直接使用img显示图片就可以了,如下:

<img name="qrCodeImg" src="/images/itlao5.jpg" style="width: 80%;" />

然而,当同一个页面有多个二维码时,会出现怎样的情况呢?

今天碰到的需求中就在同一个页面有三个二维码,按照上面的方法,写了三个img,长按不同二维码img打开不同的公众号或小程序。然而,实际的效果与想象中的有点差别:在部分手机上,不管长按哪个img,都是识别了第一个img,试了三台手机,除了华为P20正常,VIVO和华为X5都出现该问题,后来测试P20在部分情况下也有该问题。
不知道怎么回事,网上一顿搜索,说是二维码识别功能是先截屏然后在识别截取的图片,然后结合我P20正常的情况,应该是截取了点击位置附近一定像素的屏幕,然后进行识别。如果该截屏区域内有多个二维码,会识别到第一个,这就造成了同一屏内多个二维码识别出错的问题。

然后想解决思路,方案有三种:

  1. 二维码间隔拉大,保证同一屏内只显示一个完整的二维码;
  2. 先弄个二维码列表(不用img,用background放图片),然后点击二维码打开详情页(或者弹出层) ,长按详情页或弹出层img识别
  3. 既然是截屏识别第一个完整二维码,那在截屏时将点击的img图片显示到顶部&
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权限。同时,由于微信小程序的隐私政策限制,这种方式并不适用于直接在页面识别,通常建议引导用户去其他地方完成描操作,如点击一个按钮跳转至新的界面。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

IT-老五

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值