小程序参数获取方式

页面跳转

页面与页面之间跳转并传递参数

js 复制代码
wx.navigateTo({
	url:'/pages/demo?age=12&name=tom'
})

接收参数

js 复制代码
// onLoad生命周期中获取
onLoad(options){
	console.log(options.age) // 12
	console.log(options.name) // tom
}

普通二维码

进入到微信小程序后台进行配置

扫描普通二维码打开小程序

获取参数

例如配置的小程序链接为:https://xxx/xxx?age=12&name=tom

js 复制代码
// 二维码链接内容会以参数 `q` 的形式带给页面,
// 微信传递进来会进行编码,需要进行decodeURIComponent解码
onLoad(options){
	const url = decodeURIComponent(options.q)
	console.log(url) // https://xxx/xxx?age=12&name=tom	
}

获取到的是完整的链接地址,我们需要通过?分隔,得到我们所需要的参数,改进上面代码。

js 复制代码
const queryURLParams = (url: string) => {
    const pattern = /(\w+)=(\w+)/gi; //定义正则表达式
    const parames: Record<string, any> = {}; // 定义参数对象
    url.replace(pattern, ($, $1, $2) => {
        parames[$1] = $2;
        return "";
    });
    return parames;
};
onLoad(options){
	const url = decodeURIComponent(options.q)
	const params = queryURLParams(url) // {age:12,name:'tom'}
}

小程序码

生成小程序码

小程序码可以通过微信后台手动生成,也可以通过请求服务端接口进行生成

获取小程序码

获取参数

例如配置的二维码地址为:pages/demo?scene=12|tom

小程序码传递参数有格式限制,例如中文字符等,最好自行使用encodeURIComponent进行编码后传递

js 复制代码
// 微信传递进来会进行编码,需要进行decodeURIComponent解码
onLoad(options){
	const params = decodeURIComponent(options.scene)
	console.log(params) // 12|tom
}
相关推荐
最新资讯动态2 分钟前
使用“一次开发,多端部署”,实现Pura X阔折叠的全新设计
前端
爱泡脚的鸡腿17 分钟前
HTML CSS 第二次笔记
前端·css
灯火不休ᝰ33 分钟前
前端处理pdf文件流,展示pdf
前端·pdf
智践行35 分钟前
Trae开发实战之转盘小程序
前端·trae
最新资讯动态41 分钟前
DialogHub上线OpenHarmony开源社区,高效开发鸿蒙应用弹窗
前端
lvbb661 小时前
框架修改思路
前端·javascript·vue.js
树上有只程序猿1 小时前
Java程序员需要掌握的技术
前端
从零开始学安卓1 小时前
Kotlin(三) 协程
前端
阿镇吃橙子1 小时前
一些手写及业务场景处理问题汇总
前端·算法·面试