## key-value本地数据存储 app、小程序、web,均提供了方便的key-value模式的本地数据存储,通过键值对的方式存取数据。 uni-app的Storage在不同端的实现不同: - H5端为localStorage,浏览器限制5M大小,是缓存概念,可能会被清理 - App端为原生storage,无大小限制,不是缓存,是持久化的 - 各个小程序端为其自带的storage api,数据存储生命周期跟小程序本身一致,即除用户主动删除或超过一定时间被自动清理,否则数据都一直可用。 * 微信小程序单个 key 允许存储的最大数据长度为 1MB,所有数据存储上限为 10MB。 * 支付宝小程序单条数据转换成字符串后,字符串长度最大200*1024。同一个支付宝用户,同一个小程序缓存总上限为10MB。 * 百度小程序策略[详见](https://smartprogram.baidu.com/docs/develop/api/storage/save_process/) * 抖音小程序策略[详见](https://developer.open-douyin.com/docs/resource/zh-CN/mini-app/develop/api/data-caching/tt-get-storage) * `Android` 端采用应用内SQLIte数据库储存,每个apk对应一个数据库文件,储存位置为:/data/data/io.dcloud.uniappx(基座包名)/databases/DCStorage,同apk内的不同应用,以表名区分。 **注意** - `uni-`、`uni_`、`dcloud-`、`dcloud_`为前缀的key,为系统保留关键前缀。如`uni_deviceId`、`uni_id_token`,请开发者为key命名时避开这些前缀。 - 非App平台清空Storage会导致uni.getSystemInfo获取到的deviceId改变 ## uni.setStorage(options) @setstorage ## uni.setStorageSync(key, data) @setstoragesync :::warning 参数 `data` 为对象字面量时,需要通过 `as UTSJSONObject` 明确类型,例如: ```js uni.setStorageSync('obj', {"a": 1} as UTSJSONObject) ``` ::: ## uni.getStorage(options) @getstorage > 注意:获取一个不存在的 key 会触发 fail 回调,返回错误信息为 "getStorage:fail data not found" 的错误。 ## uni.getStorageSync(key) @getstoragesync > 注意:同步方法获取一个不存在的 key 会返回空字符串,而不是 null ## uni.getStorageInfo(options) @getstorageinfo ## uni.getStorageInfoSync() @getstorageinfosync ## uni.removeStorage(options) @removestorage ## uni.removeStorageSync(key) @removestoragesync ## uni.clearStorage(option?) @clearstorage ## uni.clearStorageSync() @clearstoragesync