A simple library that allows you to use local storage in Angular 5+.
- Use command + F or ctrl + F to search for a keyword.
- Contributions welcome, please see contribution guide.
- 🐸 Observable based
- 🐫 Easy implementation
- 🐭 Lazy loading compatible
- 🐑 Angular Universal compatible
- 🐼 Automatic JSON (de)serialization
- 🐦 Ahead-Of-Time compilation compatible
- 🐹 Library can be consumed by Angular CLI, Webpack, or SystemJS
Click here to play with the example
To use ngx-storage in your project install it via npm
or yarn
:
$ npm install @stanvanheumen/ngx-storage --save
# or
$ yarn add @stanvanheumen/ngx-storage
Add the NgxStorageModule
to your imports array in your CoreModule
.
import {NgxStorageModule} from '@stanvanheumen/ngx-storage';
@NgModule({
imports: [NgxStorageModule]
})
export class AppModule {}
Since the
StorageService
contains state it is important to only import theNgxStorageModule
in yourCoreModule
.
The StorageService
has the following API:
Returns the value associated to the specified token wrapped in an observable stream that will get updated each time the user sets a new value in the storage.
// For a primitive type like string, number and boolean.
const string$ = this.storage.get<string>('my-string');
// For an advanced object or array.
const object$ = this.storage.get<MyAdvancedObject>('my-advanced-object');
The value is deserialized using the
JSON.parse()
method.
Associates a value to the specified token.
// For a primitive type like string, number and boolean.
this.storage.set<string>('my-local-storage-token', 'my-new-value');
// For an advanced object or array.
this.storage.set<MyAdvancedObject>('my-advanced-object', {name: 'Test', description: 'Lorem Ipsum'});
The value is serialized using the
JSON.stringify()
method.
Removes the value associated to the specified token.
this.storage.remove('my-local-storage-token');
Removes all key-value pairs from the storage.
this.storage.clear();
import {Component, OnInit} from '@angular/core';
import {StorageService} from '@stanvanheumen/ngx-storage';
import {Observable} from 'rxjs/Observable';
@Component({
selector: 'app-root',
template: `
<pre><code>Current value in the local storage : {{ data$ | async | json }}</code></pre>
<button (click)="setStorageValue('Awesome')">Set value to <strong>"Awesome"</strong></button>
<button (click)="setStorageValue('Cool')">Set value to <strong>"Cool"</strong></button>
<button (click)="setStorageValue('Hello world!')">Set value to <strong>"Hello world!"</strong></button>
<button (click)="removeStorageValue()">Clear the value</button>
`
})
export class AppComponent implements OnInit {
data$: Observable<string>;
constructor(private storage: StorageService) {
}
ngOnInit() {
this.data$ = this.storage.get<string>('my-local-storage-token');
}
setStorageValue(value: string) {
this.storage.set<string>('my-local-storage-token', value);
}
removeStorageValue() {
this.storage.remove('my-local-storage-token');
}
}