按自定义的优先级使用 Cookie、LocalStorage、SessionStorage 存储
自动检测浏览器是否支持,若不支持使用下一优先级项进行存储
- Cookie storage options can be modified
- Compact size 8.1KB (2.3KB gzipped)
You can install it via yarn or NPM.
$ yarn add @gaoming13/browser-storage
$ npm i @gaoming13/browser-storage
<script src="https://cdn.jsdelivr.net/npm/@gaoming13/browser-storage@1.0.1"></script>
<script src="https://unpkg.com/@gaoming13/browser-storage@1.0.1"></script>
import browserStorage from '@gaoming13/browser-storage';
// 定义存储的优先级,按照优先级找浏览器支持的的存储
// `c` 指代 Cookie, `s` 指代 SessionStorage, `l` 指代 LocalStorage
browserStorage.setPriority('csl');
// 存储某个值
browserStorage.setItem('item1', 'hello world');
// 获取某个值
browserStorage.getItem('item1'); // It will return `hello world`
// 删除某个值
browserStorage.removeItem('item1');
// 设置优先级,限制只使用 Cookie 存储
browserStorage.setPriority('c');
// 设置存储键名的前缀(例如存储了 `item2`,那么实际存储的键名就是 `h5-item2`)
browserStorage.setPreKey('h5-');
// 设置 Cookie 存储选项
// 设置 Expires/Max-Age = Session
browserStorage.setCookieOptions({ path: '/abc', domain: 'local.com' });
// 更多选项信息请查阅 [https://github.com/jshttp/cookie#options-1](https://github.com/jshttp/cookie#options-1)
browserStorage.setCookieOptions({ path: '/abc', maxAge: 86400, domain: 'local.com' });
// 存储某个值
browserStorage.setItem('item2', 'xxxx');
getItem(key)
获取某个值setItem(key, value)
存储某个值removeItem(key)
删除某个值setPriority(priority)
设置存储方式优先级- @example
obj.setPriority('c')
- @example
obj.setPriority('cl')
- @example
obj.setPriority('cs')
- @example
obj.setPriority('cls')
- @example
setPreKey(key)
设置键名前缀- @example
obj.setPreKey('h5-')
- @example
cookieStoreSetPreKey(key)
设置 Cookie 键名前缀- @example
obj.cookieStoreSetPreKey('h5-')
- @example
localStoreSetPreKey(key)
设置 LocalStorage 键名前缀seesionStoreSetPreKey(key)
设置 SessionStorage 键名前缀cookieStoreIsSupport()
浏览器是否支持 CookielocalStoreIsSupport()
浏览器是否支持 LocalStorageseesionStoreIsSupport()
浏览器是否支持 SessionStoragecookieSetOptions
设置 Cookie 存储选项- @example
setCookieOptions({ path: '/abc', maxAge: 86400, domain: 'local.com' })
- @example
Details changes for each release are documented in the release notes.
If you find a bug or want to contribute to the code or documentation, you can help by submitting an issue or a pull request.