uniapp项目页面之间传值

一、传单个或多个参数

方法:直接在地址后面拼接

1、在将要跳转的页面上地址后面拼接要传递的参数,传递多个时用&符拼接

//任务列表页传递id  跳转到相应的任务详情页
gettaskList(id){
//传递多个参数时直接用&符拼接
				uni.navigateTo({
					url:'gettaskList?id=${id}'
				})

}

2、接收时,在页面的onload函数中接收传递过来的参数

// 任务详情页通过 onLoad 生命周期中接传递过来的参数 id
onLoad(option){
 console.log('上一个页面传递过来的参数', option)
 console.log('id', option.id)
 console.log('item', option.item)
 // 接下来就是你需要该id做些什么,比如通过id查询到该详情等
}

二、传递对象

如需要传递的参数有很多时,由uniapp 跳转页面api 的 url 有长度限制,需使用以下方式进行数据传递:

// item 为该列表的每一项的数据对象;encodeURIComponent 为uniapp 提供的api
getTaskList(item) {
	uni.navigateTo({
		 url: `getTaskList?item=${encodeURIComponent(JSON.stringify(item))}`,
	});
}

接收时

// 同样onLoad 生命周期中进行接收, decodeURIComponent 为uniapp 提供的api
onLoad(option) {
	const item = JSON.parse(decodeURIComponent(option.item));
	console.log('上一个页面传递过来的参数对象',item );
	// 接下来就是你需要该对象数据做些什么,当然这里你可以直接赋值给data绑定的数据
	this.objData = item;
}

注意:传递数据的时候必须使用 JSON.stringify 将其转为 JSON 字符串,然后接收的时候也必须使用 JSON.parse 来进行解析!
操作数组也是一样的,因为数组也是对象

### UniApp 页面递参数的方法 在 UniApp 开发过程中,页面间的参数递是一个常见的需求。这不仅限于简单的字符串或数类型的参数,还可以是较为复杂的数据结构如对象。 #### 使用 URL 参数递简单数据 最基础的方式就是利用URL中的查询参数来进行页面间的数据输。这种方式适合用于少量且不敏感的信息交换。当目标页面加载时,可通过`$route.query`获取这些参数[^1]。 ```javascript // 跳转并附带参数 uni.navigateTo({ url: '/pages/targetPage?name=John&age=30' }); // 在 targetPage.vue 的 onLoad 方法里读取参数 export default { onLoad(options) { console.log(`姓名:${options.name}, 年龄:${options.age}`); } } ``` #### 利用全局变量存储临时数据 对于一些不需要长期保存但在多个页面间共享的数据,可以考虑创建一个全局的对象作为容器,在需要的时候存入取出相应的。不过这种方法需要注意清理不再使用的属性以免造成内存泄漏[^2]。 ```javascript Vue.prototype.$globalData = {}; // 定义全局变量 // 设置全局变量 this.$globalData.userInfo = { name: 'Alice', age: 28 }; // 获取全局变量 console.log(this.$globalData.userInfo); ``` #### 发布/订阅模式进行跨页通信 针对更复杂的场景,比如从子组件向父级或其他兄弟页面发送消息的情况,则推荐采用发布-订阅机制。通过 `uni.emit()` 和 `uni.on()` 可以轻松实现这一点。此方法特别适用于处理异步操作后的回调通知,例如支付完成后的状态同步。 ```javascript // 子组件内触发事件 uni.emit('updateMasq', {msg: '页面刷新'}); // 父页面监听该事件 uni.on('updateMasq', function (data) { console.log('接收到的消息:', data.msg); }); ``` 以上三种方式涵盖了大部分情况下UniApp应用内的页面交互需求。开发者可以根据实际情况灵活选用最适合的技术方案来满足项目的特定要求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值