微信小程序中的數(shù)據(jù)存儲實現(xiàn)方式
全局變量globalData
在最初創(chuàng)建小程序時,app.js文件中App方法中傳入的對象里面默認(rèn)添加了globalData參數(shù)。在所有的頁面中我們都可以通過getApp方法獲取到這個App方法傳入的對象,進(jìn)而拿到其中的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接口和視圖層進(jìn)行數(shù)據(jù)交互,從而改變wxml視圖層顯示內(nèi)容。
如果不需要將data中的值傳入到視圖層中,不建議使用setData而是改用對象方式操作??梢杂行Ч?jié)省性能。
在頁面初始化時,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類似。不局限于某個頁面,任何位置都可以通過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)前程序的默認(rèn)空間,coder可以在其下創(chuàng)建文件夾,添加文件等。
- fileName是存儲數(shù)據(jù)時的文件名。
- data是要存儲的數(shù)據(jù),可以是圖片。
- encoding:編碼格式,當(dāng)data為圖片時可已調(diào)整為二進(jìn)制。
讀取
存取數(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)方式的文章就介紹到這了,更多相關(guān)小程序數(shù)據(jù)存儲內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript閉包傳參和事件的循環(huán)綁定示例探討
按常理循環(huán)綁定事件,但是得到的結(jié)果卻不是想要的,下面有個不錯的示例,可以為大家詳細(xì)分解下2014-04-04小程序獲取當(dāng)前位置加搜索附近熱門小區(qū)及商區(qū)的方法
這篇文章主要介紹了小程序獲取當(dāng)前位置加搜索附近熱門小區(qū)及商區(qū)的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-04-04原生js實現(xiàn)的移動端可拖動進(jìn)度條插件功能詳解
這篇文章主要介紹了原生js實現(xiàn)的移動端可拖動進(jìn)度條插件功能,結(jié)合實例形式詳細(xì)分析了javascript拖動進(jìn)度條插件的具體定義與使用技巧,需要的朋友可以參考下2019-08-08