ngrx/store

简介

ngrx/store:保存了ReduxAPI的核心概念,使用RxJS扩展的Redux实现。使用可观察对象来简化了监听事件的订阅等操作。

dispatcher,reducer,state都是基于BehaviorSubject的
BehaviorSubject:储存着要发射给消费者的最新的值。无论何时一个新的观察者订阅它,都会立即接受到这个来自BehaviorSubject的”当前值”。

创建一个应用存储的接口可以便于理解reducers是如何用于应用的。如果需要额外的功能,存储可以扩展新的键值对来容纳更新的模型。

store的select方法:定义当state改变时,state的哪一部分应该被返回,返回一个Observable对象。

一个小例子:

// The "items" reducer performs actions on our list of items
export const items = (state: any = [], {type, payload}) => {
  switch (type) {
    default:
      return state;
  }
};

// The "selectedItem" reducer handles the currently selected item
export const selectedItem = (state: any = null, {type, payload}) => {
  switch (type) {
    default:
      return state;
  }
};

export interface AppStore {
  items: Item[];
  selectedItem: Item;
}

this.videos$ = this.store.select(state => state.videos);

使用store作为状态管理的优点

  • 集中管理state
  • 性能
    使用onPush的变更检测策略;且可直接在模板中使用observable对象
  • 易于测试
    因为reducer是纯函数
  • 易于调试
    便于观察状态的改变,以及何时哪里为什么出错;
    middleware???

工作流程

Created with Raphaël 2.1.0 ngrx/store工作流程 展示组件上用户交互 是否为异步操作? 容器组件调用服务类 服务类调用dispatch方法 使用reducer生成新的state 模板中使用async的变量,自动重新渲染;store自动调用observer 等待进一步的用户交互 容器组件直接调用dispatch方法 yes no

ngrx/store使用步骤

  1. 安装相应npm包

    npm install ngrx/store ngrx/core --save-dev

  2. 定义store模块

  3. 创建action与reducer
  4. 连接reducer与store模块
  5. 在组件或服务中使用reducer
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值