localstoragejs

A LocalStorage wrapper with some extra functions

Usage no npm install needed!

<script type="module">
  import localstoragejs from 'https://cdn.skypack.dev/localstoragejs';
</script>

README

LocalStorage

A wrapper library for HTML5's native localStorage, with some utility functions, validation and namespacing.

Installation

You can install the library by using bower install localstoragejs or you can checkout the repo directly. Depending on your configuration, either incude the file in the src directory or the one in the dist directory.

The module exposes both a global LocalStorage variable and, if you're using it, a requirejs module.

Usage

You can use the module directly from the LocalStorage global variable through its static methods, that allow for a straightforward wrapping of the localStorage functions. The only difference is that whatever you're saving in the dictionary is automatically stringified/parsed as JSON.

LocalStorage.set('myValue', 15); // Saves the value 15 as `myValue`.
LocalStorage.get('myValue'); // Retrieves whatever is saved in `myValue`.
LocalStorage.remove('myValue'); // Clears the `myValue` key
LocalStorage.clear(); // Removes everything from local storage.
LocalStorage.toggleConstructorCheck(value) // Enables or disables the check on the value constructor (disallows the serialization of exotic objects)
LocalStorage.allowConstructor(constructor); // Allows the serialization of the specified constructor.

If you want more flexibility, you can create an instance of the LocalStorage object. This will namespace all the keys to the name of the instance, and will also allow you to use validators.

Namespacing

Namespacing allows you to 'group' keys together by using a common prefix, which is based on the string you pass to the LocalStorage constructor.

// Creates an instance of the LocalStorage object. 
// All the keys will be namespaced within "DB"
var db = new LocalStorage('DB'); 

// Saves the array [1,2,3] in the 'myValue' key for the "DB" namespace. 
// This means that the real key will be "DB:myValue".
db.set('myValue', [1,2,3]); 

// Retrieves [1,2,3] from the 'myValue' key within the "DB" namespace. 
// This means that you're retrieving whatever is saved within the "DB:myValue" key.
db.get('myValue'); 

// Removes the 'myValue' key from the DB namespace. 
// You're actually removing the "DB:myValue" key.
db.remove('myValue'); 

// Retrieves all the keys for the current object's namespace. 
// In this instance, you're retrieving all the keys that begin with "DB:"
db.all(); 

// Clears all the keys associated to the object's namespace. 
// Here, you'll be removing all the keys that begin with "DB:"
db.clear(); 

Validation

Sometimes you might want to validate a value before saving it. Validators serve exactly that purpose and come in two flavors: one-shot and permanent.

When you create an instance of the LocalStorage object, you have the option to pass a second parameter with some options. Right now, the only option available is the blockingValidation option which, if set to true, makes the set call throw a LocalStorageException when failing validation instead of simply returning false.

One-shot validators

A one-shot validator is evaluated within the scope of a single set call and is not saved within your LocalStorage object instance.

var db = new LocalStorage('DB');

// This will fail since the passed value does not pass the validation test.
db.set('username', 'fred', function(value) {
    return value.length >= 8;
});

Permanents validators

A permanent validator is associated with a key and will be called anytime you attempt to save a value for that key. A permanent validator has lower priority than a one-shot validator, so you can always override it by passing a one-shot validator (or true) to a set call.

// By passing the 'blockingValidation' option, we make 
// the 'set' call throw an exception when validation fails.
var db = new LocalStorage('DB', {blockingValidation: true});

db.setValidator('username', function(value) {
    return value.length >= 8;
});

// This will fail
db.set('username', 'fred');

// This will pass
db.set('username', 'fred1234');

// This too wil pass
db.set('username', 'fred', function(value) { return value === 'fred'; });

// If you just want to skip validation for a single call, go ahead:
db.set('username', 'brad', true);

If you want to clear a permanent validator, or you want to clear all of them, you can do so by calling either the clearValidator or the clearValidators functions:

// This will clear the permanent validator associated with the 'username' key
db.clearValidator('username');

// This will clear all the permanent validators on this instance of LocalStorage
db.clearValidators();

Chaining

The following instance methods are chainable:

  • set (when validation passes)
  • remove
  • all
  • setValidator
  • clearValidator
  • clearValidators

That's pretty much it (for now)!

A note on compatibility

I'm assuming this library will be used in projects made for modern browsers. I haven't put any effort in testing compatibility other than to check if the localStorage variable is present on the global scope. If you feel that this is not sufficient, please send a PR and I will consider it!

Promises?

Even though all this stuff is synchronous, I'm toying with the idea of using promises instead of/alongside return values. For example, there could be an option like usePromises that makes each method return a promise instead of the result of the operation or the object itself (for chainable methods). This would remove the ambiguity of the return value for the set method, and would allow - with some tweaking - the use of asynchronous validators. For this purpose I would need to make this library dependent on a library such as Q or BlueBird. Thoughts?

Contributing

If you find bugs or things you don't like, please send a PR. Remember to build the minified version of library using grunt and update the README if required.

License

MIT