Home

Awesome

simpleStorage

Cross-browser key-value store database to store data locally in the browser.

simpleStorage is a fork of jStorage that only includes the minimal set of features. Basically it is a wrapper for native JSON + localStorage with some TTL magic mixed in.

The module has no dependencies, you can use it as a standalone script (introduces simpleStorage global) or as an AMD module. All modern browsers (including mobile) are supported, older browsers (IE7, Firefox 3) are not.

simpleStorage is very small - about 1kB in size when minimized and gzipped.

Build Status

Install

Quickest way to get up and running woulr be to use jsDelivr CDN:

<script src="https://cdn.jsdelivr.net/npm/simplestorage.js@0.2.1/simpleStorage.min.js"></script>

Otherwise you can download simpleStorage.js or install it with bower:

bower install simpleStorage

and include the following script in your web application: bower_components/simpleStorage/simpleStorage.js

or install with npm

npm install simplestorage.js

Support simpleStorage development

Donate to author

If you want to support with Bitcoins, then my wallet address is 15Z8ADxhssKUiwP3jbbqJwA21744KMCfTM

Usage

simpleStorage API is a subset of jStorage with slight modifications, so for most cases it should work out of the box if you are converting from jStorage. Main difference is between return values - if an action failed because of an error (storage full, storage not available, invalid data used etc.), you get the error object as the return value. jStorage never indicated anything if an error occurred.

Possible error codes (from err.code):

set(key, value[, options])

Store or update a value in local storage.

simpleStorage.set(key, value[, options])

Where

// the following entry expires in 100 seconds
simpleStorage.set(key, value, {TTL: 100000})

Return values

get(key)

Retrieve a value from local storage.

value = simpleStorage.get(key)

Where

Method returns the value for a key or undefined if the key was not found.

hasKey(key)

Checks if there's a value with the given key in the local storage.

simpleStorage.hasKey(key)

Where

Method returns true if the given key exists, false otherwise.

deleteKey(key)

Removes a value from local storage.

simpleStorage.deleteKey(key)

Return values

setTTL(key, ttl)

Set a millisecond timeout. When the timeout is reached, the key is removed automatically from local storage.

simpleStorage.setTTL(key, ttl)

Where

Return values

getTTL(key)

Retrieve remaining milliseconds for a key with TTL

ttl = simpleStorage.getTTL(key)

Where

Return values

flush()

Clear all values

simpleStorage.flush()

Return values

index()

Retrieve all used keys as an array

list = simpleStorage.index()

Returns an array of keys.

storageSize()

Get used storage in symbol count

simpleStorage.storageSize()

canUse()

Check if local storage can be used

simpleStorage.canUse()

Returns true if storage is available

Demo

See demo here.

Tests

See QUnit tests here.

License

Unlicense