微信小程序页面间传值

小程序传值的方式有正向传值和反向传值

正向传值:上一页面 --> 下一页面

  • url 传值

  • 本地储存
  • 全局的 app 对象

反向传值:下一页面 --> 上一页面

  • 本地储存
  • 全局的 app 对象

一、正向传值

  • url 传值

A页面代码

// 点击列表
clickReleaseItem: function (e) {
  var release = e.currentTarget.dataset.para;
  wx.navigateTo({
    url: '../../pages/releaseDetail/releaseDetail?release=' + JSON.stringify(release)
  })
},

B页面代码

/**
 * 生命周期函数--监听页面加载
 */
onLoad: function (options) {
  this.setData({
    // 获取上个页面传过来的列表发布信息
    currentRelease: JSON.parse(options.release)
  });
},
  • 本地储存

A页面代码

/* 把发布信息异步存储到缓存当中 */
wx.setStorage({
  key: 'releases',
  data: list,
})

B页面代码

// 本地获取收藏的发布信息
var that = this;
wx.getStorage({
  key: 'releases',
  success: function (res) {
    that.setData({
      releaseArray: res.data
    });
  },
})
  • 全局的 app 对象

A页面代码

var app = getApp();
app.releaseData = release;

B页面代码

 

var app = getApp();
var release = app.releaseData;

二、反向传值

  • 本地储存

B页面代码

/* 把发布信息异步存储到缓存当中 */
wx.setStorage({
  key: 'releases',
  data: list,
})
// 返回上一页
wx.navigateBack();

A页面代码

/**
 * 生命周期函数--监听页面显示
 */
onShow: function () {
  // 本地获取收藏的发布信息
  var that = this;
  wx.getStorage({
    key: 'releases',
    success: function (res) {
      that.setData({
        releaseArray: res.data
      });
    },
  })
},
  • 全局的 app 对象

B页面代码

var app = getApp();
app.releaseData = release;

A页面代码

var app = getApp();
/**
 * 生命周期函数--监听页面显示
 */
onShow: function () {
  var releaseData = app.releaseData;
  this.setData({
    release: releaseData
  });
},


链接:https://www.jianshu.com/p/62f071651b07
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值