小程序页面间传递数据的方式

互联网 20-7-1
最近在做小程序项目,发现小程序的页面间经常需要传递一些数据。根据自己的了解和熟悉,针对不同的数据要求,总结到有几种不同的传数据方式,下面做一下简单的介绍归纳。

第一种:页面跳转时通过url传递

使用wx.navigateTowx.redirectTo 的时候,可以将部分数据放在 url 里面,并在新页面 onLoad 的时候获取且初始化。

//pageA.js  // Navigate wx.navigateTo({   url: '../pageB/pageB?name=lin&gender=male', })  // Redirect wx.redirectTo({   url: '../pageB/pageB?name=lin&gender=male', })  // pageB.js ... Page({   onLoad: function(option){     console.log(option.name + 'is' + option.gender);     this.setData({       option: option     });   } })

需要注意的问题:

  1. 使用wx.navigateTowx.redirectTo时,不允许跳转到 tab 所包含的页面;
  2. onLoad只执行一次;

第二种:使用全局变量来传递

在 app.js 文件中定义全局变量 globalData,旧页面将要传递的数据赋值存放在里面,新页面调用全局变量获取传递数据值。

// app.js  App({      // 全局变量   globalData: {     name: null   } })  //pageA.js ··· getApp().globalData.name = "lin";   //pageB.js ··· this.setData({   userName: getApp().globalData.name });

要注意的问题:

  1. 使用的时候,直接使用 getApp() 拿到存储的信息。

第三种:使用本地缓存

使用小程序中的本地缓存Storage,旧页面将传递数据存入缓存中,新页面通过调用获取缓存的API得到数据。

//pageA.js ··· wx.setStorageSync('sessionId', res.sessionId);   //pageB.js ··· var sessionId = wx.getStorageSync('sessionId');

要注意的问题:

  1. Storage每次存入会覆盖掉原来该 key 对应的内容。
  2. 如果用户主动删除小程序或因存储空间原因被系统清理,Storage中数据将被清除。
  3. 单个 key 允许存储的最大数据长度为 1MB,所有数据存储上限为 10MB。

推荐教程:《微信小程序》

以上就是小程序页面间传递数据的方式的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: 小程序
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:八分钟带你入门微信小程序开发

相关资讯