微信小程序中的數(shù)據(jù)存儲(chǔ)實(shí)現(xiàn)方式
全局變量globalData
在最初創(chuàng)建小程序時(shí),app.js文件中App方法中傳入的對(duì)象里面默認(rèn)添加了globalData參數(shù)。在所有的頁面中我們都可以通過getApp方法獲取到這個(gè)App方法傳入的對(duì)象,進(jìn)而拿到其中的globalData。
const App = getApp(); const openId = App.globalData.openId; App.globalData.openId = 1; delete App.globalData.openId;
globalData的值是一個(gè)對(duì)象,我們可以用對(duì)待對(duì)象的方式一樣調(diào)用它。(globalData并非一定叫這個(gè)名字)
頁面私有變量 data
每個(gè)頁面的js邏輯層頁面都是在Page方法中傳入了一個(gè)對(duì)象。其中data的值一般用來存儲(chǔ)當(dāng)前頁面內(nèi)的變量值。其主要用途是通過setData接口和視圖層進(jìn)行數(shù)據(jù)交互,從而改變wxml視圖層顯示內(nèi)容。
如果不需要將data中的值傳入到視圖層中,不建議使用setData而是改用對(duì)象方式操作??梢杂行Ч?jié)省性能。
在頁面初始化時(shí),data中的數(shù)據(jù)都會(huì)和視圖層進(jìn)行數(shù)據(jù)交互。如果進(jìn)一步處理,我們還可以在對(duì)象中添加localData專門存儲(chǔ)當(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也是小程序中很常用的一種存儲(chǔ)方式,和全局變量globalData類似。不局限于某個(gè)頁面,任何位置都可以通過wx提供的接口獲取到其中的值。
優(yōu)點(diǎn)是:可以長(zhǎng)期存儲(chǔ),即使退出重新登陸數(shù)據(jù)不會(huì)消失。(上限存儲(chǔ)10M)
缺點(diǎn)是:異步行為,每次存取耗時(shí)相對(duì)較長(zhǎng)。
wx提供了增、刪、改、查接口(增、改都是一個(gè)set接口),下面只舉一個(gè)存儲(chǔ)數(shù)據(jù)例子:
異步存儲(chǔ)(根據(jù)設(shè)備性能的不同,你還真不知道他會(huì)存多久)
wx.setStorage({ key: 'key', data: 'value', success: res => { ... } }) // 支持promise wx.setStorage({key: 'key', data: 'value'}) .then(res => { ... })
同步存儲(chǔ)(會(huì)造成阻塞~)
wx.setStorageSync('key', 'value') ...
文件存儲(chǔ) fileSysteManager
fileSysteManager(下簡(jiǎn)稱fs)可以把文字、圖片類型的數(shù)據(jù)通過文件的方式存儲(chǔ)到本地。存儲(chǔ)上限10M(之前記得200M,后來翻文檔看到的都是10了),長(zhǎng)期存儲(chǔ),不刪除小程序數(shù)據(jù)就不會(huì)消失。
寫入:
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是存儲(chǔ)數(shù)據(jù)時(shí)的文件名。
- data是要存儲(chǔ)的數(shù)據(jù),可以是圖片。
- encoding:編碼格式,當(dāng)data為圖片時(shí)可已調(diào)整為二進(jìn)制。
讀取
存取數(shù)據(jù)時(shí)要牢記文件名和存儲(chǔ)位置;
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ù)存儲(chǔ)實(shí)現(xiàn)方式的文章就介紹到這了,更多相關(guān)小程序數(shù)據(jù)存儲(chǔ)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js實(shí)現(xiàn)圖片淡入淡出切換簡(jiǎn)易效果
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)圖片淡入淡出切換簡(jiǎn)易效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08javascript閉包傳參和事件的循環(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)的移動(dòng)端可拖動(dòng)進(jìn)度條插件功能詳解
這篇文章主要介紹了原生js實(shí)現(xiàn)的移動(dòng)端可拖動(dòng)進(jìn)度條插件功能,結(jié)合實(shí)例形式詳細(xì)分析了javascript拖動(dòng)進(jìn)度條插件的具體定義與使用技巧,需要的朋友可以參考下2019-08-08一款好用的移動(dòng)端滾動(dòng)插件BetterScroll
BetterScroll 是一款重點(diǎn)解決移動(dòng)端各種滾動(dòng)場(chǎng)景需求的開源插件,用于滾動(dòng)列表、選擇器、輪播圖、索引列表、開屏引導(dǎo)等應(yīng)用場(chǎng)景,感興趣的一起來了解一下2021-09-09