Check out our latest tech talk, "JavaScript Supply Chain Security" presented by VP of Security, Adam Baldwin.Watch it here »

This package has been deprecated

Author message:

This package has moved. Please 'npm install @angular-redux/store' instead.


5.1.2 • Public • Published


Angular 2 bindings for Redux.

For Angular 1 see ng-redux

Join the chat at CircleCI npm version npm downloads

Ng2Redux lets you easily connect your Angular 2 components with Redux, while still respecting the Angular 2 idiom.

Features include:

  • The ability to access slices of store state as Observables
  • Compatibility with existing Redux middleware and enhancers
  • Compatibility with the existing Redux devtools Chrome extension
  • A rich, declarative selection syntax using the @select decorator

In addition, we are committed to providing insight on clean strategies for integrating with Angular 2's change detection and other framework features.

Table of Contents


Ng2Redux has a peer dependency on redux, so we need to install it as well.

npm install --save redux ng2-redux

Quick Start

import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './containers/app.module';

Import the NgReduxModule class and add it to your application module as an import. Once you've done this, you'll be able to inject NgRedux into your Angular 2 components. In your top-level app module, you can configure your Redux store with reducers, initial state, and optionally middlewares and enhancers as you would in Redux directly.

import { NgReduxModule, NgRedux } from 'ng2-redux';
import reduxLogger from 'redux-logger';
import { rootReducer } from './reducers';
interface IAppState { /* ... */ };
  /* ... */
  imports: [ /* ... */, NgReduxModule ]
export class AppModule {
  constructor(ngRedux: NgRedux<IAppState>) {
    ngRedux.configureStore(rootReducer, {}, [ createLogger() ]);

Or if you prefer to create the Redux store yourself you can do that and use the provideStore() function instead:

import {
} from 'redux';
import { NgReduxModule, NgRedux } from 'ng2-redux';
import reduxLogger from 'redux-logger';
import { rootReducer } from './reducers';
interface IAppState { /* ... */ };
export const store: Store<IAppState> = createStore(
  /* ... */
  imports: [ /* ... */, NgReduxModule ]
class AppModule {
  constructor(ngRedux: NgRedux<IAppState>) {

Now your Angular 2 app has been reduxified! Use the @select decorator to access your store state, and .dispatch() to dispatch actions:

import { select } from 'ng2-redux';
  template: '<button (click)="onClick()">Clicked {{ count | async }} times</button>'
class App {
  @select() count$: Observable<number>;
  constructor(private ngRedux: NgRedux<IAppState>) {}
  onClick() {
    this.ngRedux.dispatch({ type: INCREMENT });


Here are some examples of Ng2Redux in action:

Companion Packages


In-Depth Usage

Ng2Redux uses an approach to redux based on RxJS Observables to select and transform data on its way out of the store and into your UI or side-effect handlers. Observables are an efficient analogue to reselect for the RxJS-heavy Angular world.

Read more here: Select Pattern

We also have a number of 'cookbooks' for specific Angular 2 topics:


npm i ng2-redux

Downloadsweekly downloads









last publish


  • avatar
  • avatar
  • avatar
Report a vulnerability