What is NgRx/Store framework in
Angular? What is the use? This article will take you to understand the NgRx/Store data state management framework, the basic principles in ngrx/store, and learn the simple usage of the framework through examples.
【Related tutorial recommendation: "angular tutorial"】
ngrx/store
Yes A state management library based onRxJS
, inspired byRedux
. InNgRx
, state is composed of a map containing functions ofaction
andreducer
. TheReducer
function is called via the dispatch ofaction
and the current or initial state, and finally an immutable state is returned byreducer
.
State management of large and complex front-endAngular/AngularJS
projects has always been a frustrating task Headache problem. In AngularJS (version 1.x), state management is usually handled by a mix of services, events,$rootScope
. In Angular (version 2), component communication makes state management clearer, but it is still a bit complicated, and many methods are used depending on the data flow direction.
The view layer initiates an action throughdispatch
, andReducer
receives itaction
, based on theaction.type
type, determines execution, changes the state, returns a new state tostore
, and is updated bystore
##state.
state
) memory
state uses the observable object ofAction
-Store
to access
is the carrier of information. It sends data toreducer
, and thenreducer
updatesstore
.Actions
is the only waystore
can accept data.In
, the interface ofAction
is as follows:// actions包括行为类型和对应的数据载体 export interface Action { type: string; payload?: any; }
Describes the expected status change type. For example, add to-doADD_TODO
, addDECREMENT
, etc.payload
is the data sent tostore
to be updated.store
The code for dispatchingaction
is similar to the following:// 派发action,从而更新store store.dispatch({ type: 'ADD_TODO', payload: 'Buy milk' });
Specifies the specific state changes corresponding to the behavior. It is a pure function that changes the state by receiving the previous state and dispatching behavior to return a new object as the next state. The new object is usually implemented usingObject.assign
and extended syntax.
When developing, special attention should be paid to the purity of the function. Because pure functions:// reducer定义了action被派发时state的具体改变方式 export const todoReducer = (state = [], action) => { switch(action.type) { case 'ADD_TODO': return [...state, action.payload]; default: return state; } }
stores all the immutable state in the application. Thestore
inngrx/store
is the observable object of theRxJS
state and the observer of the behavior.You can use
to distribute actions. You can also use the Store'sselect()
method to obtain observable objects, then subscribe to observe and react after the status changes.What we describe above is the basic process. In the actual development process, asynchronous operations such as API requests and browser storage will be involved, which requires
andservices
.effects
consists ofaction
Trigger, perform a series of logic and then issue one or moreaction
that need to be added to the queue, and then processed byreducers
.
Simple example
, mainly layout, the code is component logic2. Define user:
3、添加表单:在组件 按照上述的4个原则定义相应的 在文件 effects侦听从Store调度的动作,执行某些逻辑,然后分派新动作 一般情况下只在这里调用API 通过返回一个action给reducer进行操作来改变store的状态 effects总是返回一个或多个action(除非 完 更多编程相关知识,请访问:编程视频!! The above is the detailed content of Quickly understand the NgRx/Store framework in Angular in one article. For more information, please follow other related articles on the PHP Chinese website!export class User { id: number; username: string; password: string; email: string; avatar: string; clear(): void { this.id = undefined; this.username = ""; this.password = ""; this.email = ""; this.avatar = "./assets/default.jpg"; } }
LoginComponent
增加Form
表单NGRX Store
Actions
reducers
定义状态auth.reducers.ts
中创建状态,并初始化export interface AuthState { isAuthenticated: boolean; user: User | null; errorMessage: string | null; } export const initialAuthState: AuthState = { isAuthenticated: false, user: null, errorMessage: null };
actions
定义行为export enum AuthActionTypes { Login = "[Auth] Login", LoginSuccess = "[Auth] Login Success", LoginFailure = "[Auth] Login Failure" } export class Login implements Action { readonly type = AuthActionTypes.Login; constructor(public payload: any) {} }
service
实现数据交互(服务器)@Injectable() export class AuthService { private BASE_URL = "api/user"; constructor(private http: HttpClient) {} getToken(): string { return localStorage.getItem("token"); } login(email: string, pwd: string): Observable
@Effect with {dispatch: false})
)
@Effect() Login: Observable