微信扫二维码,跳转到小程序

常见的跳转小程序的方式

  1. scheme,NFC封签感应跳转、网页网址重定向跳转
  2. 小程序码,扫码跳转
  3. 加密URL LINK,点击跳转
  4. 微信扫二维码,跳转

本文主要涉及第四点,微信扫二维码跳转。

需求一开始要求:NFC封签感应,打开小程序。用scheme实现。

需求增加,希望扫码打开小程序,也用scheme实现。开发了一个H5页面,在页面中,通过接口获取对应的scheme,网址重定向到scheme,大部分APP会自动唤起微信小程序。

需求变更,希望上面两种方式扫出来的结果不同。scheme生成时,参数是固定的,用scheme实现的跳转小程序,无法区分来源,所以换了扫码打开小程序的实现方式。

中间遇到问题,方式1H5网页跳转的链接 二维码,在需求变更时,已印刷在物料上。

还好方式4是可行的。

解决思路

首先,二维码的本质就是一个链接地址

其次登录微信小程序微信公众平台,设置扫普通链接二维码打开小程序

最后业务代码处理二维码链接的传参,目标页面接收二维码链接地址的参数。

具体过程

  1. 登录微信公众平台,找到 开发管理> 开发设置> 扫普通链接二维码打开小程序

下拉找到这个配置入口:

按照要求设置即可,不懂的都有提示引导。

二维码地址:你自定义的链接地址,但是,域名要通过检验文件,按要求把校验文件上传到服务器即可。

小程序路径:你的链接跳转的目标页面路径。

测试范围:根据自身需要选择即可,发布线上那就必须是线上版本。

js 复制代码
onLoad: function(e) {
	// e={"q":"https://url/index?orderId=1"};
    const qrUrl = decodeURIComponent(e.q) // 获取到二维码原始链接内容
    const params = getWxMiniProgramUrlParam(qrUrl);//此处就是我们要获取的参数 json
    let orderId = params.orderId;
}

//解析链接地址中的参数方法
getWxMiniProgramUrlParam (url) {
  let theRequest = {};
  if(url.indexOf("#") != -1){
	  const str=url.split("#")[1];
	  const strs=str.split("&");
	  for (let i = 0; i < strs.length; i++) {
	  	theRequest[strs[i].split("=")[0]] = decodeURI(strs[i].split("=")[1]);
	  }
  }else if(url.indexOf("?") != -1){
	  const str=url.split("?")[1];
	  const strs=str.split("&");
	  for (let i = 0; i < strs.length; i++) {
	  	theRequest[strs[i].split("=")[0]] = decodeURI(strs[i].split("=")[1]);
	  }
  }
  return theRequest;
}
相关推荐
tcdos9 小时前
不止扫码 — 微信生态深度融合(登录 + 支付 + 消息)
后端·微信小程序
小徐_23331 天前
Wot UI 2.2.0 发布:Button 新增 subtle,VideoPreview 预览体验继续增强
前端·微信小程序·uni-app
蜗牛前端3 天前
codex 全流程开发上线的高颜值礼簿小程序
前端·微信小程序
爱勇宝7 天前
我想认真做一件小事:让孩子和家长更好地互动
微信小程序·小程序·云开发
唯火锅不可辜负7 天前
避坑指南:iOS 下 scroll-view 嵌套 fixed 布局的“翻车”现场与修复
微信小程序
didiplus7 天前
运维人的随身神器:我把25个常用工具塞进了微信小程序
微信小程序
一份执念8 天前
uni-app 小程序分包限制处理与主包体积优化实战
前端·微信小程序
一份执念8 天前
ECharts 安装与使用完全指南:从全量引入到小程序分包优化
微信小程序·echarts
skiyee9 天前
🔥UniApp 仅需 5 行代码!实现所有页面中控制应用主题变化
前端·微信小程序
Jinkey10 天前
要用户手机号真的是为了打骚扰电话吗?浅谈微信生态会员账号体系与资产合并
后端·微信·微信小程序