小程序页面间传递数据的方式有哪些?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1202个文字,预计阅读时间需要5分钟。
最近在做一个小程序项目,发现小程序的页面间经常需要传递一些数据。根据我的理解和经验,针对不同的数据需求,有以下几种不同的传数方式:
1. 页面栈传递:通过页面栈的索引来传递数据,适用于简单数据传递。
2. 页面参数传递:通过URL的查询参数来传递数据,适用于数据量不大且需要持久化存储的情况。
3. 全局变量传递:通过设置全局变量来传递数据,适用于跨页面或模块的数据共享。
4. 事件传递:通过监听事件并传递数据,适用于异步数据传递。
5. 数据库传递:通过数据库存储和查询数据,适用于大量数据传递和持久化存储。
下面简单介绍一下这几种传数方式:
1. 页面栈传递:通过设置页面栈的索引,在目标页面通过`getCurrentPages()`获取页面栈,获取到目标页面后再获取数据。
2. 页面参数传递:在页面跳转时,将数据作为URL的查询参数传递,在目标页面通过`onLoad()`函数获取参数。
3. 全局变量传递:在需要共享数据的页面中,设置全局变量,其他页面通过`getApp().globalData`获取数据。
4. 事件传递:通过触发自定义事件并传递数据,在目标页面监听事件并获取数据。
5. 数据库传递:使用小程序提供的数据库API,将数据存储在云数据库中,通过查询和更新数据库来传递数据。
最近在做小程序项目,发现小程序的页面间经常需要传递一些数据。根据自己的了解和熟悉,针对不同的数据要求,总结到有几种不同的传数据方式,下面做一下简单的介绍归纳。第一种:页面跳转时通过url传递
使用wx.navigateTo 与 wx.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 }); } })
需要注意的问题:
- 使用
wx.navigateTo与wx.redirectTo时,不允许跳转到 tab 所包含的页面; onLoad只执行一次;
适用:
这种方式一般适用于少数页面之间需要少量数据传递,如B页面需要A页面中的1-2个数据等等。
第二种:使用全局变量来传递
在 app.js 文件中定义全局变量 globalData,旧页面将要传递的数据赋值存放在里面,新页面调用全局变量获取传递数据值。
// app.js App({ // 全局变量 globalData: { name: null } }) //pageA.js ··· getApp().globalData.name = "lin"; //pageB.js ··· this.setData({ userName: getApp().globalData.name });
要注意的问题:
- 使用的时候,直接使用
getApp()拿到存储的信息。
适用:
这种方式一般适用于多个页面或者全部页面都需要获取使用同一个数据,比如一开始进入首页就获取到的用户信息等;
第三种:使用本地缓存
使用小程序中的本地缓存Storage,旧页面将传递数据存入缓存中,新页面通过调用获取缓存的API得到数据。
//pageA.js ··· wx.setStorageSync('sessionId', res.sessionId); //pageB.js ··· var sessionId = wx.getStorageSync('sessionId');
要注意的问题:
- Storage每次存入会覆盖掉原来该 key 对应的内容。
- 如果用户主动删除小程序或因存储空间原因被系统清理,Storage中数据将被清除。
- 单个 key 允许存储的最大数据长度为 1MB,所有数据存储上限为 10MB。
适用:
这种方式一般适用于即使小程序退出然后再重新进入,也要保留的数据,类似于登录状态的保留等。
推荐教程:《微信小程序》
以上就是小程序页面间传递数据的方式的详细内容,更多请关注自由互联其它相关文章!
本文共计1202个文字,预计阅读时间需要5分钟。
最近在做一个小程序项目,发现小程序的页面间经常需要传递一些数据。根据我的理解和经验,针对不同的数据需求,有以下几种不同的传数方式:
1. 页面栈传递:通过页面栈的索引来传递数据,适用于简单数据传递。
2. 页面参数传递:通过URL的查询参数来传递数据,适用于数据量不大且需要持久化存储的情况。
3. 全局变量传递:通过设置全局变量来传递数据,适用于跨页面或模块的数据共享。
4. 事件传递:通过监听事件并传递数据,适用于异步数据传递。
5. 数据库传递:通过数据库存储和查询数据,适用于大量数据传递和持久化存储。
下面简单介绍一下这几种传数方式:
1. 页面栈传递:通过设置页面栈的索引,在目标页面通过`getCurrentPages()`获取页面栈,获取到目标页面后再获取数据。
2. 页面参数传递:在页面跳转时,将数据作为URL的查询参数传递,在目标页面通过`onLoad()`函数获取参数。
3. 全局变量传递:在需要共享数据的页面中,设置全局变量,其他页面通过`getApp().globalData`获取数据。
4. 事件传递:通过触发自定义事件并传递数据,在目标页面监听事件并获取数据。
5. 数据库传递:使用小程序提供的数据库API,将数据存储在云数据库中,通过查询和更新数据库来传递数据。
最近在做小程序项目,发现小程序的页面间经常需要传递一些数据。根据自己的了解和熟悉,针对不同的数据要求,总结到有几种不同的传数据方式,下面做一下简单的介绍归纳。第一种:页面跳转时通过url传递
使用wx.navigateTo 与 wx.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 }); } })
需要注意的问题:
- 使用
wx.navigateTo与wx.redirectTo时,不允许跳转到 tab 所包含的页面; onLoad只执行一次;
适用:
这种方式一般适用于少数页面之间需要少量数据传递,如B页面需要A页面中的1-2个数据等等。
第二种:使用全局变量来传递
在 app.js 文件中定义全局变量 globalData,旧页面将要传递的数据赋值存放在里面,新页面调用全局变量获取传递数据值。
// app.js App({ // 全局变量 globalData: { name: null } }) //pageA.js ··· getApp().globalData.name = "lin"; //pageB.js ··· this.setData({ userName: getApp().globalData.name });
要注意的问题:
- 使用的时候,直接使用
getApp()拿到存储的信息。
适用:
这种方式一般适用于多个页面或者全部页面都需要获取使用同一个数据,比如一开始进入首页就获取到的用户信息等;
第三种:使用本地缓存
使用小程序中的本地缓存Storage,旧页面将传递数据存入缓存中,新页面通过调用获取缓存的API得到数据。
//pageA.js ··· wx.setStorageSync('sessionId', res.sessionId); //pageB.js ··· var sessionId = wx.getStorageSync('sessionId');
要注意的问题:
- Storage每次存入会覆盖掉原来该 key 对应的内容。
- 如果用户主动删除小程序或因存储空间原因被系统清理,Storage中数据将被清除。
- 单个 key 允许存储的最大数据长度为 1MB,所有数据存储上限为 10MB。
适用:
这种方式一般适用于即使小程序退出然后再重新进入,也要保留的数据,类似于登录状态的保留等。
推荐教程:《微信小程序》
以上就是小程序页面间传递数据的方式的详细内容,更多请关注自由互联其它相关文章!

