1.使用页面栈
说明:只对当前页面栈中存在的页面生效
// aaa.js
Page({
data:{
name:‘xiaowang’,
age:22
},
eatFood:function(food){
console.log('eating '+ food)
},
})
// bbb.js
Page({
onLoad: function (options) {
//获取当前页面栈
const pages = getCurrentPages();
//获取上一页面对象
let prePage = pages[pages.length - 2];
console.log(prePage.data.name) //‘xiaowang’
prePage.eatFood(‘apple’)//eating apple
},
})
页面栈,这是一个极其强大功能,它本质上不是向页面传参而是直接修改页面参数和方法。通过页面栈我们可以拿到该页面的对象,然后就可以对该页面的各项数据和函数进行操作。但是这种方法只能在b页面去操作a页面,并不能在a页面操作b页面,因为此时页面栈中还没有b。并且该方法也仅限于通过wx.navagateTo()或 跳转 这两种方式进入b页面才可使用,因为其他方式跳转到b页面时已经销毁了其他所有页面,页面栈中已经没有上一个页面了。
2.组件跳转
// aaa.wxml
<view>
<navigator open-type="switchTab" url="/bbb?id=1">跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面</navigator>
<navigator open-type="reLaunch" url="/bbb?id=1">关闭所有页面,打开到应用内的某个页面</navigator>
<navigator open-type="redirectTo" url="/bbb?id=1">关闭当前页面,跳转到应用内的某个页面。但是不允许跳转到 tabbar 页面</navigator>
<navigator open-type="navigateTo" url="/bbb?id=1">保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面</navigator>
</view>
//以上四种路由方式在传参和接参上没有任何区别
// bbb.wxml
Page({
//地址传参带过来的参数只能在该方法的options参数中获取
onLoad:function(options){
console.log(options.id) //'1' ,无论传的变量是数字、布尔还是对象接收的时候都是字符串
},
})
3.使用globalData
说明:globalData是小程序app.js中固定的一个属性,存储的数据可在全项目任意处使用
// app.js
App({
globalData:{},
})
// aaa.js
const app = getApp();
app.globalData.name='xiaowang';
// bbb.js
const app = getApp();
console.log(app.globalData.name) //xiaowang
globalData与storage原理相同都是将数据放在一个公共的地方全应用随意取用,但是他们的数据不推送也不关联,即globalData和storage中的数据更新了,但已经获取过值的页面其对应的值并 不会更新。
解决办法:将各页面获取值的事件放到onShow()中,每次页面进入前台的时候都会重新从globalData和storage中取值。
4.使用storage
说明:storage是微信分给每个小程序的缓存,单个参数最大1M,数据总和最大10M
代码示例:
// aaa.js
Page({
data:{
name:'xiaowang'
},
})
//只支持原生类型、Date、及能够通过JSON.stringify序列化的对象
wx.setStorageSync('name',this.data.name)
// bbb.js
console.log(wx.getStorageSync(name)) //xiaowang