NgRx Actions是NgRx中用于处理状态更新的工具。在Angular中,通常情况下我们使用Actions作为Redux中的“action creators”,将Actions生成为一个动作对象,然后将其发送给NgRx Store。然而,有些开发者可能会混淆将Actions生成为动作对象和重新使用Actions的方式。
首先,让我们先来看看生成动作对象的示例代码:
import { createAction, props } from '@ngrx/store';
export const addTodo = createAction('[Todo] Add', props<{ text: string }>());
export const deleteTodo = createAction('[Todo] Delete', props<{ id: number }>());
在这个示例代码中,我们使用了createAction函数创建了两个Actions,一个用于添加Todo并带有文本信息,另一个用于删除Todo并带有Id号。下面是如何在组件中使用这些Actions:
import { Component, OnInit } from '@angular/core';
import { Store } from '@ngrx/store';
import { addTodo, deleteTodo } from '../actions/todo.actions';
@Component({
selector: 'app-todo',
templateUrl: './todo.component.html',
styleUrls: ['./todo.component.css']
})
export class TodoComponent implements OnInit {
public text: string;
constructor(private store: Store) { }
ngOnInit() {
}
addTodo() {
this.store.dispatch(addTodo({ text: this.text }));
this.text = '';
}
deleteTodo(id: number) {
this.store.dispatch(deleteTodo({ id: id }));
}
}
在这个示例代码中,我们从todo.actions模块导入了addTodo和deleteTodo这两个Actions,然后我们在addTodo函数中调用了this.store.dispatch()函数发送一个动作对象,这个动作对象带有属性text,删除操作中也是同理。
需要注意的是,我们发送到Store的是一个动作对象,而不是一个Action。所以,一定要区分Actions和Action Objects。
如果我们直接重复使用Actions,它们就会产生问题,