微信小程序中的數(shù)據(jù)存儲實(shí)現(xiàn)方式
全局變量globalData
在最初創(chuàng)建小程序時(shí),app.js文件中App方法中傳入的對象里面默認(rèn)添加了globalData參數(shù)。在所有的頁面中我們都可以通過getApp方法獲取到這個(gè)App方法傳入的對象,進(jìn)而拿到其中的globalData。
const App = getApp(); const openId = App.globalData.openId; App.globalData.openId = 1; delete App.globalData.openId;
globalData的值是一個(gè)對象,我們可以用對待對象的方式一樣調(diào)用它。(globalData并非一定叫這個(gè)名字)
頁面私有變量 data
每個(gè)頁面的js邏輯層頁面都是在Page方法中傳入了一個(gè)對象。其中data的值一般用來存儲當(dāng)前頁面內(nèi)的變量值。其主要用途是通過setData接口和視圖層進(jìn)行數(shù)據(jù)交互,從而改變wxml視圖層顯示內(nèi)容。
如果不需要將data中的值傳入到視圖層中,不建議使用setData而是改用對象方式操作。可以有效節(jié)省性能。
在頁面初始化時(shí),data中的數(shù)據(jù)都會和視圖層進(jìn)行數(shù)據(jù)交互。如果進(jìn)一步處理,我們還可以在對象中添加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類似。不局限于某個(gè)頁面,任何位置都可以通過wx提供的接口獲取到其中的值。
優(yōu)點(diǎn)是:可以長期存儲,即使退出重新登陸數(shù)據(jù)不會消失。(上限存儲10M)
缺點(diǎn)是:異步行為,每次存取耗時(shí)相對較長。
wx提供了增、刪、改、查接口(增、改都是一個(gè)set接口),下面只舉一個(gè)存儲數(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)前程序的默認(rèn)空間,coder可以在其下創(chuàng)建文件夾,添加文件等。
- fileName是存儲數(shù)據(jù)時(shí)的文件名。
- data是要存儲的數(shù)據(jù),可以是圖片。
- encoding:編碼格式,當(dāng)data為圖片時(shí)可已調(diào)整為二進(jìn)制。
讀取
存取數(shù)據(jù)時(shí)要牢記文件名和存儲位置;
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ù)存儲實(shí)現(xiàn)方式的文章就介紹到這了,更多相關(guān)小程序數(shù)據(jù)存儲內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript閉包傳參和事件的循環(huán)綁定示例探討
按常理循環(huán)綁定事件,但是得到的結(jié)果卻不是想要的,下面有個(gè)不錯(cuò)的示例,可以為大家詳細(xì)分解下2014-04-04
小程序獲取當(dāng)前位置加搜索附近熱門小區(qū)及商區(qū)的方法
這篇文章主要介紹了小程序獲取當(dāng)前位置加搜索附近熱門小區(qū)及商區(qū)的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-04-04
原生js實(shí)現(xiàn)的移動端可拖動進(jìn)度條插件功能詳解
這篇文章主要介紹了原生js實(shí)現(xiàn)的移動端可拖動進(jìn)度條插件功能,結(jié)合實(shí)例形式詳細(xì)分析了javascript拖動進(jìn)度條插件的具體定義與使用技巧,需要的朋友可以參考下2019-08-08

