微信小程序传参过来了,但是数据没有获取到

使用本方法前,已经采用encodeURIComponent把拼接的参数编码之后,拼接在链接上,在接受的页面的onLoad生命周期,接收到参数之后,采用decodeURIComponent进行解码的操作,如果这个也不行,不是说不行,而是第一次跳转没有解析出来数据,也就是页面没有数据。需要第二次跳转才有数据。那么就是在微信小程序中,URL参数传递有以下限制:

  1. 长度限制:URL过长会被截断
  1. 编码问题:特殊字符可能导致解析失败
  1. 生命周期问题:页面加载时序可能影响数据获取

解决方案就是只传递关键的参数。或者跳转过去再做查询功能

传递的参数设置

javascript 复制代码
	
			clickPatient(item) {
			
				if (this.patientInfo) {
					// 简化方案:只传递最关键的几个参数
					const params = {
						patientId: item.patientId || '',
						brName: item.brName || '',
						brSfzh: item.brSfzh || '',
						groupStatus: item.groupStatus || '0',
						companyCode: item.companyCode || '',
						rid: item.rid || ''
					};
					// 同时使用存储作为备份
					uni.setStorageSync('current_patient_backup', item);
					
					// 构建URL参数
					const urlParams = Object.keys(params)
						.filter(key => params[key]) // 过滤掉空值
						.map(key => `${key}=${encodeURIComponent(params[key])}`)
						.join('&');
					
					console.log('URL参数字符串:', urlParams);
					
					uni.navigateTo({
						url: `./patientDetail?${urlParams}`,
					});
				}
				
			},

接受参数设置

javascript 复制代码
onLoad(options) {
			this.mrPatientInfo = this.$patientInfo.getCurrentPatient()
			
			let patientData = null;
			
			// 简化方案:直接从URL参数构建数据
			if (options.patientId) {
				patientData = {
					patientId: decodeURIComponent(options.patientId),
					brName: options.brName ? decodeURIComponent(options.brName) : '',
					brSfzh: options.brSfzh ? decodeURIComponent(options.brSfzh) : '',
					groupStatus: options.groupStatus || '0',
					companyCode: options.companyCode ? decodeURIComponent(options.companyCode) : '',
					rid: options.rid || ''
				};
			
			}
			
			// 备用方案:从存储获取
			if (!patientData || !patientData.patientId) {
				try {
					const backupData = uni.getStorageSync('current_patient_backup');
					if (backupData && backupData.patientId) {
						patientData = backupData;
						// 清理备份数据
						uni.removeStorageSync('current_patient_backup');
					}
				} catch (error) {
				}
			}
相关推荐
老华带你飞3 小时前
租房平台|租房管理平台小程序系统|基于java的租房系统 设计与实现(源码+数据库+文档)
java·数据库·小程序·vue·论文·毕设·租房系统管理平台
项目題供诗3 小时前
微信小程序开发教程(八)
微信小程序·小程序
00后程序员张10 小时前
iOS App 混淆与资源保护:iOS配置文件加密、ipa文件安全、代码与多媒体资源防护全流程指南
android·安全·ios·小程序·uni-app·cocoa·iphone
低代码布道师10 小时前
少儿舞蹈小程序(12)作品列表查询搭建
低代码·小程序
编程迪12 小时前
基于Java+Vue开发的家政服务系统源码适配H5小程序APP
小程序·家政小程序·家政系统源码·家政系统·家政源码
拼图20913 小时前
微信小程序——云函数【使用使用注意事项】
微信小程序·小程序
fakaifa16 小时前
【独立版】智创云享知识付费小程序 v5.0.23+小程序 搭建教程
小程序·uni-app·知识付费·源码下载·智创云享独立版
2501_9160074716 小时前
Transporter App 使用全流程详解:iOS 应用 ipa 上传工具、 uni-app 应用发布指南
android·ios·小程序·https·uni-app·iphone·webview
fakaifa17 小时前
CRMEB多门店 v3.3源码 无授权限制+PC端+uniapp前端
小程序·uni-app·商城小程序·技术教程·源码下载·crmeb多门店
低代码布道师17 小时前
少儿舞蹈小程序(13)作品播放量累加及点赞
低代码·小程序