小程式頁頁間傳遞資料的方式

hzc
發布: 2020-07-01 09:55:11
轉載
2737 人瀏覽過

最近在做小程式項目,發現小程式的頁間常常需要傳遞一些資料。根據自己的了解和熟悉,針對不同的資料要求,總結到有幾種不同的傳資料方式,以下做一個簡單的介紹歸納。

第一種:頁面跳轉時透過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只執行一次;

#適用:
這種方式一般適用於少數頁面之間需要少量資料傳遞,如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
});
登入後複製

要注意的問題:

  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。

適用:
這種方式一般適用於即使小程式退出然後再重新進入,也要保留的數據,類似於登入狀態的保留等。

推薦教學:《微信小程式

以上是小程式頁頁間傳遞資料的方式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:jianshu.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!