Skip to content

Latest commit

 

History

History
92 lines (65 loc) · 1.97 KB

README.md

File metadata and controls

92 lines (65 loc) · 1.97 KB

@ngrx/store

Codeship Status for ngrx/store NPM Version for ngrx/store

RxJS powered Redux for Angular2 apps

installation

  • Make sure you have angular2 installed via npm : npm install angular
  • Install from npm : npm install @ngrx/store

usage

  • Create a reducer function for each data type you have:
//counter.ts
import {Reducer, Action} from '@ngrx/store';

export const INCREMENT = 'INCREMENT';
export const DECREMENT = 'DECREMENT';
export const RESET = 'RESET';

export const counter:Reducer<number> = (state:number = 0, action:Action) => {
	
	switch (action.type) {
		case INCREMENT:
			return state + 1;
			break;
		
		case DECREMENT:
			return state - 1;
			break;
			
		case RESET:
			return 0;
			break;
	
		default:
			return state;
			break;
	}
}
  • In your app's main module, import those reducers and use the provideStore(reducers, initialState) function to provide them to Angular's injector:
import {bootstrap} from 'angular2/platform/bootstrap';
import {provideStore} from '@ngrx/store';
import {App} from './myapp';

import {counter} from './counter';

bootstrap(App, [ provideStore({counter}, {counter: 0}) ];
  • You can then inject the Store service into your Components and Services:
import {Store} from '@ngrx/store';
import {INCREMENT, DECREMENT, RESET} from './counter';

@Component({
	selector: 'my-app',
	template: `
	  <button (click)="increment()">Increment</button>
		<div>Current Count: {{ counter | async }}</div>
		<button (click)="decrement()">Decrement</button>
	`
})
class MyApp {
	counter: Observable<number>;
	constructor(public store: Store){
		this.counter = store.select('counter');
	}
	increment(){
		this.store.dispatch({ action: INCREMENT });
	}
	decrement(){
		this.store.dispatch({ action: INCREMENT });
	}
	
}