search
HomeWeb Front-endJS TutorialQuickly understand the NgRx/Store framework in Angular in one article

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.

Quickly understand the NgRx/Store framework in Angular in one article

【Related tutorial recommendation: "angular tutorial"】

ngrx/store Yes A state management library based on RxJS, inspired by Redux. In NgRx, state is composed of a map containing functions of action and reducer. The Reducer function is called via the dispatch of action and the current or initial state, and finally an immutable state is returned by reducer.

Quickly understand the NgRx/Store framework in Angular in one article

State Management

State management of large and complex front-end Angular/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.

Basic principles in ngrx/store

The view layer initiates an action through dispatch, and Reducer receives it action, based on the action.type type, determines execution, changes the state, returns a new state to store, and is updated by store ##state.

Quickly understand the NgRx/Store framework in Angular in one article

    ##State
  • (state) is the state (state) memory
  • Action
  • (Behavior) Describes changes in state
  • Reducer
  • (Reducer/Reduction function) Calculate the new state based on the previous state and current behavior. The method inside is pure The function state uses the observable object of
  • State
  • and the observer of Action - Store to access
Actions (behavior)

Actions

is the carrier of information. It sends data to reducer, and then reducer updates store. Actions is the only way store can accept data. In

ngrx/store

, the interface of Action is as follows: <pre class='brush:php;toolbar:false;'>// actions包括行为类型和对应的数据载体 export interface Action { type: string; payload?: any; }</pre>

type

Describes the expected status change type. For example, add to-do ADD_TODO, add DECREMENT, etc. payload is the data sent to store to be updated. storeThe code for dispatching action is similar to the following: <pre class='brush:php;toolbar:false;'>// 派发action,从而更新store store.dispatch({ type: &amp;#39;ADD_TODO&amp;#39;, payload: &amp;#39;Buy milk&amp;#39; });</pre>

Reducers

Reducers

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 using Object.assign and extended syntax. <pre class='brush:php;toolbar:false;'>// reducer定义了action被派发时state的具体改变方式 export const todoReducer = (state = [], action) =&gt; { switch(action.type) { case &amp;#39;ADD_TODO&amp;#39;: return [...state, action.payload]; default: return state; } }</pre>When developing, special attention should be paid to the purity of the function. Because pure functions:

will not change the state outside its scope
  • The output only depends on the input
  • The same input will always get the same output
Store

store

stores all the immutable state in the application. The store in ngrx/store is the observable object of the RxJS state and the observer of the behavior. You can use

Store

to distribute actions. You can also use the Store's select() 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

effects

and services. effects consists of actionTrigger, perform a series of logic and then issue one or more action that need to be added to the queue, and then processed by reducers.

Quickly understand the NgRx/Store framework in Angular in one article

Use the ngrx/store framework to develop applications, always maintain only one state, and reduce API calls.

Simple example

A brief introduction to the login module of a management system.

Create Form

1. Add components:

LoginComponent

, mainly layout, the code is component logic2. Define user:

User Model

<pre class='brush:php;toolbar:false;'>export class User { id: number; username: string; password: string; email: string; avatar: string; clear(): void { this.id = undefined; this.username = &quot;&quot;; this.password = &quot;&quot;; this.email = &quot;&quot;; this.avatar = &quot;./assets/default.jpg&quot;; } }</pre><p>3、添加表单:在组件<code>LoginComponent增加Form表单

NGRX Store

按照上述的4个原则定义相应的Actions

Quickly understand the NgRx/Store framework in Angular in one article

  • 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<any> {
            const url = `${this.BASE_URL}/login`;
            return this.http.post<User>(url, { email, pwd });
        }
    }
  • effects侦听从Store调度的动作,执行某些逻辑,然后分派新动作

    • 一般情况下只在这里调用API

    • 通过返回一个action给reducer进行操作来改变store的状态

    • effects总是返回一个或多个action(除非@Effect with {dispatch: false})

Quickly understand the NgRx/Store framework in Angular in one article

  • @Effect()
    Login: Observable<any> = this.actions.pipe(
        ofType(AuthActionTypes.Login),   //执行Login响应
        map((action: Login) => action.payload),
        switchMap(payload => {
            return this.authService.login(payload.email, payload.password).pipe(
                map(user => {
                    return new LoginSuccess({ uid: user.id, email: payload.email });
                }),
                catchError(error => {
                    return of(new LoginFailure(error));
                })
            );
        })
    );
    
    //失败的效果
    @Effect({ dispatch: false })
    LoginFailure: Observable<any> = this.actions.pipe(ofType(AuthActionTypes.LoginFailure));
    
    //成功的效果
    @Effect({ dispatch: false })
    LoginSuccess: Observable<any> = this.actions.pipe(
        ofType(AuthActionTypes.LoginSuccess),
        tap(user => {
            localStorage.setItem("uid", user.payload.id);
            this.router.navigateByUrl("/sample");
        })
    );

更多编程相关知识,请访问:编程视频!!

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!

Statement
This article is reproduced at:掘金社区. If there is any infringement, please contact admin@php.cn delete
JavaScript in Action: Real-World Examples and ProjectsJavaScript in Action: Real-World Examples and ProjectsApr 19, 2025 am 12:13 AM

JavaScript's application in the real world includes front-end and back-end development. 1) Display front-end applications by building a TODO list application, involving DOM operations and event processing. 2) Build RESTfulAPI through Node.js and Express to demonstrate back-end applications.

JavaScript and the Web: Core Functionality and Use CasesJavaScript and the Web: Core Functionality and Use CasesApr 18, 2025 am 12:19 AM

The main uses of JavaScript in web development include client interaction, form verification and asynchronous communication. 1) Dynamic content update and user interaction through DOM operations; 2) Client verification is carried out before the user submits data to improve the user experience; 3) Refreshless communication with the server is achieved through AJAX technology.

Understanding the JavaScript Engine: Implementation DetailsUnderstanding the JavaScript Engine: Implementation DetailsApr 17, 2025 am 12:05 AM

Understanding how JavaScript engine works internally is important to developers because it helps write more efficient code and understand performance bottlenecks and optimization strategies. 1) The engine's workflow includes three stages: parsing, compiling and execution; 2) During the execution process, the engine will perform dynamic optimization, such as inline cache and hidden classes; 3) Best practices include avoiding global variables, optimizing loops, using const and lets, and avoiding excessive use of closures.

Python vs. JavaScript: The Learning Curve and Ease of UsePython vs. JavaScript: The Learning Curve and Ease of UseApr 16, 2025 am 12:12 AM

Python is more suitable for beginners, with a smooth learning curve and concise syntax; JavaScript is suitable for front-end development, with a steep learning curve and flexible syntax. 1. Python syntax is intuitive and suitable for data science and back-end development. 2. JavaScript is flexible and widely used in front-end and server-side programming.

Python vs. JavaScript: Community, Libraries, and ResourcesPython vs. JavaScript: Community, Libraries, and ResourcesApr 15, 2025 am 12:16 AM

Python and JavaScript have their own advantages and disadvantages in terms of community, libraries and resources. 1) The Python community is friendly and suitable for beginners, but the front-end development resources are not as rich as JavaScript. 2) Python is powerful in data science and machine learning libraries, while JavaScript is better in front-end development libraries and frameworks. 3) Both have rich learning resources, but Python is suitable for starting with official documents, while JavaScript is better with MDNWebDocs. The choice should be based on project needs and personal interests.

From C/C   to JavaScript: How It All WorksFrom C/C to JavaScript: How It All WorksApr 14, 2025 am 12:05 AM

The shift from C/C to JavaScript requires adapting to dynamic typing, garbage collection and asynchronous programming. 1) C/C is a statically typed language that requires manual memory management, while JavaScript is dynamically typed and garbage collection is automatically processed. 2) C/C needs to be compiled into machine code, while JavaScript is an interpreted language. 3) JavaScript introduces concepts such as closures, prototype chains and Promise, which enhances flexibility and asynchronous programming capabilities.

JavaScript Engines: Comparing ImplementationsJavaScript Engines: Comparing ImplementationsApr 13, 2025 am 12:05 AM

Different JavaScript engines have different effects when parsing and executing JavaScript code, because the implementation principles and optimization strategies of each engine differ. 1. Lexical analysis: convert source code into lexical unit. 2. Grammar analysis: Generate an abstract syntax tree. 3. Optimization and compilation: Generate machine code through the JIT compiler. 4. Execute: Run the machine code. V8 engine optimizes through instant compilation and hidden class, SpiderMonkey uses a type inference system, resulting in different performance performance on the same code.

Beyond the Browser: JavaScript in the Real WorldBeyond the Browser: JavaScript in the Real WorldApr 12, 2025 am 12:06 AM

JavaScript's applications in the real world include server-side programming, mobile application development and Internet of Things control: 1. Server-side programming is realized through Node.js, suitable for high concurrent request processing. 2. Mobile application development is carried out through ReactNative and supports cross-platform deployment. 3. Used for IoT device control through Johnny-Five library, suitable for hardware interaction.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

SecLists

SecLists

SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)