溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

微信小程序中數(shù)據(jù)存儲實現(xiàn)方式有哪些

發(fā)布時間:2021-08-21 09:04:44 來源:億速云 閱讀:460 作者:小新 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細講解有關(guān)微信小程序中數(shù)據(jù)存儲實現(xiàn)方式有哪些,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。


全局變量globalData

在最初創(chuàng)建小程序時,app.js文件中App方法中傳入的對象里面默認添加了globalData參數(shù)。在所有的頁面中我們都可以通過getApp方法獲取到這個App方法傳入的對象,進而拿到其中的globalData。

const App = getApp();
const openId = App.globalData.openId;
App.globalData.openId = 1;
delete App.globalData.openId;

globalData的值是一個對象,我們可以用對待對象的方式一樣調(diào)用它。(globalData并非一定叫這個名字)

頁面私有變量 data

每個頁面的js邏輯層頁面都是在Page方法中傳入了一個對象。其中data的值一般用來存儲當(dāng)前頁面內(nèi)的變量值。其主要用途是通過setData接口和視圖層進行數(shù)據(jù)交互,從而改變wxml視圖層顯示內(nèi)容。

如果不需要將data中的值傳入到視圖層中,不建議使用setData而是改用對象方式操作。可以有效節(jié)省性能。
在頁面初始化時,data中的數(shù)據(jù)都會和視圖層進行數(shù)據(jù)交互。如果進一步處理,我們還可以在對象中添加localData專門存儲當(dāng)前頁面所需變量

Page({
 data: {
  openId: 123
 },
 localData: {
  timeStamp: Date.now()
 }
})
this.setData({
 openId: 321
})
this.data.openId = 321;
this.localData.timeStamp = Data.now();

storage

storage也是小程序中很常用的一種存儲方式,和全局變量globalData類似。不局限于某個頁面,任何位置都可以通過wx提供的接口獲取到其中的值。

優(yōu)點是:可以長期存儲,即使退出重新登陸數(shù)據(jù)不會消失。(上限存儲10M)
缺點是:異步行為,每次存取耗時相對較長。
wx提供了增、刪、改、查接口(增、改都是一個set接口),下面只舉一個存儲數(shù)據(jù)例子:

異步存儲(根據(jù)設(shè)備性能的不同,你還真不知道他會存多久)

wx.setStorage({
 key: 'key',
 data: 'value',
 success: res => {
  ...
 }
})
// 支持promise
wx.setStorage({key: 'key', data: 'value'})
 .then(res => {
  ...
 })

同步存儲(會造成阻塞~)

wx.setStorageSync('key', 'value')
...

文件存儲 fileSysteManager

fileSysteManager(下簡稱fs)可以把文字、圖片類型的數(shù)據(jù)通過文件的方式存儲到本地。存儲上限10M(之前記得200M,后來翻文檔看到的都是10了),長期存儲,不刪除小程序數(shù)據(jù)就不會消失。

寫入:

const fs = wx.getFileSystemManager();
fs.writeFile({
  filePath: `${wx.env.USER_DATA_PATH}/_l${fileName}.txt`,
  data: JSON.stringify(data),
  encoding: 'utf8',
  success(res) { ... }
})
  • filePath中的 env.userDatapath 是wx分配給當(dāng)前程序的默認空間,coder可以在其下創(chuàng)建文件夾,添加文件等。

  • fileName是存儲數(shù)據(jù)時的文件名。

  • data是要存儲的數(shù)據(jù),可以是圖片。

  • encoding:編碼格式,當(dāng)data為圖片時可已調(diào)整為二進制。

讀取

存取數(shù)據(jù)時要牢記文件名和存儲位置;

fs.readFile({
  filePath: `${wx.env.USER_DATA_PATH}/_l${fileName}.txt`,
  encoding: 'utf8',
  position: 0,
  success(res) {
 JSON.parse(res.data) 
  }
})

移除

fs.unlink({
  filePath: `${wx.env.USER_DATA_PATH}/_l${fileName}.txt`,
  encoding: 'utf8',
  success(res) {
 ...
  }
})

fs的操作都是異步行為,要注意處理邏輯。

關(guān)于“微信小程序中數(shù)據(jù)存儲實現(xiàn)方式有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI