赞
踩
大家好,今天和大家分享一下微信小程序页面之间传参的五种方式,这个的话也是有人问了我一嘴,然后现在我和大家分享一下。
使用GPT搜索的话给我的答案是纯文字的描述,但是大致就是这样:
url上直接携带参数长度是有限的且不支持特殊符号,可用编码、解码的方式解决
代码示例:
// pagea.js //跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面 wx.switchTab({ url:'/pageb?id=1', }) //关闭所有页面,打开到应用内的某个页面 wx.reLaunch({ url: '/pageb?id=1', }) //关闭当前页面,跳转到应用内的某个页面。但是不允许跳转到 tabbar 页面 wx.redirectTo({ url: '/pageb?id=1', }) //保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面。 wx.navigateTo({ url: '/pageb?id='+ encodeURIComponent(this.data.id), }) //以上四种路由方式在传参和接参上没有任何区别 // pageb.js Page({ //地址传参带过来的参数只能在该方法的options参数中获取 onLoad:function(options){ console.log(decodeURIComponent(options.id)) //'1' ,无论传的变量是数字、布尔还是对象接收的时候都是字符串 }, })
代码示例:
// pagea.wxml
<view>
<navigator open-type="switchTab" url="/pageb?id=1">跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面</navigator>
<navigator open-type="reLaunch" url="/pageb?id=1">关闭所有页面,打开到应用内的某个页面</navigator>
<navigator open-type="redirectTo" url="/pageb?id=1">关闭当前页面,跳转到应用内的某个页面。但是不允许跳转到 tabbar 页面</navigator>
<navigator open-type="navigateTo" url="/pageb?id=1">保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面</navigator>
</view>
//以上四种路由方式在传参和接参上没有任何区别
// pageb.wxml
Page({
//地址传参带过来的参数只能在该方法的options参数中获取
onLoad:function(options){
console.log(options.id) //'1' ,无论传的变量是数字、布尔还是对象接收的时候都是字符串
},
})
storage是微信分给每个小程序的缓存,单个参数最大1M,数据总和最大10M。
代码示例:
// pagea.js
Page({
data:{
name:'xiaosun'
},
})
//只支持原生类型、Date、及能够通过JSON.stringify序列化的对象
wx.setStorageSync('name',this.data.name)
// pageb.js
console.log(wx.getStorageSync(name)) //xiaosun
globalData是小程序app.js中固定的一个属性,存储的数据可在全项目任意处使用
代码示例:
// app.js
App({
globalData:{},
})
// pagea.js
const app = getApp();
app.globalData.name='xiaosun';
// pageb.js
const app = getApp();
console.log(app.globalData.name) //xiaosun
通信通道是wx.navitageTo()独有的
代码示例:
// pagea.js wx.navigateTo({ url: '/pageb?id=1', events: { // 为指定事件添加一个监听器,获取被打开页面传送到当前页面的数据 acceptDataFromOpenedPage: function(data) {//参数名字随便起,前后页面对应上即可 //对发送回来的数据进行处理 console.log(data) }, someEvent: function(data) {//参数名字随便起,前后页面对应上即可 console.log(data) } }, success: function(res) { // 通过eventChannel向被打开页面传送数据 res.eventChannel.emit('acceptDataFromOpenerPage', { data: 'test' })//参数名字随便起,前后页面对应上即可 }, }) //pageb.js Page({ onLoad: function(option){ //获取通信通道 const eventChannel = this.getOpenerEventChannel() // 监听acceptDataFromOpenerPage事件,获取上一页面通过eventChannel传送到当前页面的数据 eventChannel.on('acceptDataFromOpenerPage', function(data) { //对发送过来的数据进行处理 console.log(data) }) //向上一页面发送数据 eventChannel.emit('acceptDataFromOpenedPage', {data: 'test'}); eventChannel.emit('someEvent', {data: 'test'}); }, })
只对当前页面栈中存在的页面生效
代码示例:
// pagea.js Page({ data:{ name:'xiaosun', age:22 }, eatFood:function(food){ console.log('eating '+ food) }, }) // pageb.js Page({ onLoad: function (options) { //获取当前页面栈 const pages = getCurrentPages(); //获取上一页面对象 let prePage = pages[pages.length - 2]; console.log(prePage.data.name) //'xiaosun' prePage.eatFood('apple')//eating apple }, })
以上就是本章的全部内容了,希望能够帮助到您,同时也希望我有写错的地方可以指出,谢谢!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。