Heim Web-Frontend js-Tutorial Angular verwendet ngrx/store für die Statusverwaltung

Angular verwendet ngrx/store für die Statusverwaltung

Jan 21, 2021 pm 05:21 PM
angular 状态管理

Dieser Artikel stellt Ihnen die Verwendung von Angular NGRX/Store-Statusverwaltung vor. Es hat einen gewissen Referenzwert. Freunde in Not können sich darauf beziehen. Ich hoffe, es wird für alle hilfreich sein.

Angular verwendet ngrx/store für die Statusverwaltung

Empfohlene verwandte Tutorials: „Angular-Tutorial

Ngrx für die Zustandsverwaltung in Angular verwenden

Einführung

ngrx/store ist inspiriert von ux und ist ein integrierter Angular-Status Verwaltungsbibliothek für RxJS, entwickelt vom Angular-Evangelisten Rob Wormald. Es hat die gleiche Kernidee wie Redux, verwendet jedoch RxJS, um das Beobachtermuster zu implementieren. Es folgt den Kernprinzipien von Redux, wurde jedoch speziell für Angular entwickelt.

Der größte Teil der Zustandsverwaltung in Angular kann durch den Dienst übernommen werden. Einer davon ist, dass der Zustandsfluss chaotisch ist, was der späteren Wartung nicht förderlich ist. Später wurde Redux als Referenz verwendet, gepaart mit den Eigenschaften von rxjs Streaming-Programmierung, einem Statusverwaltungstool für Angular.

  • StoreModule ist ein Modul im @ngrx/store API, die zum Konfigurieren des Reduzierers im Anwendungsmodul verwendet wird.

  • Aktion:

    Aktion ist eine Zustandsänderung. Es beschreibt das Eintreten eines Ereignisses, gibt jedoch nicht an, wie sich der Status der Anwendung ändert.

  • Store:

    Es stellt Store.select() und Store.dispatch() zur Verfügung, um mit dem Reduzierer zu arbeiten. Store.select() wird verwendet, um einen Selektor auszuwählen,
    Store.dispatch(
    {
    type: 'add',
    payload: {name: '111'}
    }
    )
    wird verwendet, um den Aktionstyp zu verteilen zum Reduzierer.

Drei Prinzipien der @NgRx/Store-Statusverwaltung

Zuallererst hält sich @NgRx/Store auch an die drei Grundprinzipien von Redux:

    Einzelne Datenquelle
Dieses Prinzip ist das gesamte einzelne Seite Der Status der Anwendung wird im Store in Form eines Objektbaums gespeichert.

Diese Definition ist sehr abstrakt. Sie dient dazu, alle Daten, die gemeinsam genutzt werden müssen, in Form von Javascript-Objekten zu speichern. Der Statusinhalt kann nicht direkt geändert werden. Wenn wir beispielsweise den Status der Anmeldeseite speichern müssen, müssen die Statusinformationen den Namen des angemeldeten Benutzers aufzeichnen. Wenn sich der Anmeldename ändert, können wir den im Status gespeicherten Benutzernamen nicht direkt ändern.

state =
{
    application:'angular app',
    shoppingList:['apple', 'pear']
}
Nach dem Login kopieren

    Änderungen werden mit reinen Funktionen vorgenommen (der Status kann nur durch Aufrufen von Funktionen geändert werden). /store führte außerdem ein Konzept namens Reducer (Aggregator) ein. Ändern Sie den Zustand durch den Reduzierer.
R
state={'username':'kat'},
//用户重新登录别的账户为tom
state.username = 'tom'  //在ngrx store 这个行为是绝对不允许的
Nach dem Login kopieren
ErNGRX/Store Instanzen verwenden

  • 1. Installieren Sie @ngrx/store

yarn adD @ngrx/store

2. Erstellen Sie Status, Aktion, Resicer

Status: Appstorestatus .ts

function reducer(state = 'SHOW_ALL', action) {
    switch (action.type) {
      	case 'SET_VISIBILITY_FILTER':
        	return Object.assign({}, state  ,newObj);  
        default:
        	return state  
        }
	}
Nach dem Login kopieren

reducer

appstorereducer.ts

//下面是使用接口的情况, 更规范
export interface TaskList {
  id: number;
  text: string;
  complete: boolean;
}

export const TASKSAll: TaskList[] = [
  {id: 1, text: 'Java Article 1', complete: false},
  {id: 2, text: 'Java Article 2', complete: false}
]

export interface AppState {
  count: number;
  todos: TaskList;
  // 如果要管理多个状态,在这个接口中添加即可
}

//这个是不用接口的情况
// export interface AppState {
//     count: number;
//     todos: any;
//     // 如果要管理多个状态,在这个接口中添加即可
//   }
Nach dem Login kopieren

actions
Wenn Sie die Aktion separat extrahieren müssen, lesen Sie bitte Folgendes:

5 Was tun, wenn Sie die Aktion trennen möchten?

3. Store

Root-Modul registrieren: app/app.module.ts

// reducer.ts,一般需要将state,action,reducer进行文件拆分
import { Action } from '@ngrx/store';

export const INCREMENT = 'INCREMENT';
export const DECREMENT = 'DECREMENT';
export const RESET = 'RESET';

const initialState = 0;
// reducer定义了action被派发时state的具体改变方式
export function counterReducer(state: number = initialState, action: Action) {
  switch (action.type) {
    case INCREMENT:
      return state + 1;

    case DECREMENT:
      return state - 1;

    case RESET:
      return 0;

    default:
      return state;
  }
}
Nach dem Login kopieren

4. Store

verwenden, um Store in eine Komponente oder einen Dienst zur Verwendung einzuspeisenmit appmodulearticlearticle.component.ts Komponente Zum Beispiel:

import { NgModule } from '@angular/core';
import { StoreModule } from '@ngrx/store';
// StoreModule: StoreModule是@ngrx/storeAPI中的一个模块,
// 它被用来在应用模块中配置reducer。

import {counterReducer} from './store/reducer';

@NgModule({
  imports: [
  	StoreModule.forRoot({ count: counterReducer }), // 注册store
  ],
})
export class AppModule {}
Nach dem Login kopieren

Vorlagenseite:
appmodulearticlearticle.component.html

// 组件级别
import { Component } from '@angular/core';
import { Store, select } from '@ngrx/store';
import { Observable } from 'rxjs';
import { INCREMENT, DECREMENT, RESET} from '../../store/reducer';

interface AppState {
  count: number;
}

@Component({
  selector: 'app-article',
  templateUrl: './article.component.html',
  styleUrls: ['./article.component.css']
})
export class ArticleComponent  {
  count: Observable<number>;

  constructor(private store: Store<AppState>) { // 注入store
    this.count = store.pipe(select(&#39;count&#39;)); 
    // 从app.module.ts中获取count状态流
  }

  increment() {
    this.store.dispatch({ type: INCREMENT });
  }

  decrement() {
    this.store.dispatch({ type: DECREMENT });
  }

  reset() {
    this.store.dispatch({ type: RESET });
  }
}
Nach dem Login kopieren

Hier wird das Pipe-Symbol async verwendet und der Fehler wird direkt im Untermodul gemeldet, wenn die bidirektionale Bindung von Daten erfolgen soll Im Untermodul implementiert, wird auch ein Fehler gemeldet. Konkret bezieht sich der Grund auf die in der Kursunterlagen erläuterte Frage: Die Pipe „async“ konnte nicht gefunden werden.

Wie rendere ich die Seite, ohne Pipes in der Vorlagenseite zu verwenden?

Ändern Sie es wie folgt:

<div class="state-count">

    <button (click)="increment()">增加Increment</button>
    <div>Current Count: {{ count | async }}</div>
    <button (click)="decrement()">减少Decrement</button>

    <button (click)="reset()">Reset Counter</button>
</div>
Nach dem Login kopieren


Zur Vereinfachung der Verwaltung werden Typ, Status, Aktionen und Reduzierungen im Allgemeinen separat verwaltet.

5 Was ist, wenn Sie Aktionen trennen möchten?

Erstellen Sie eine neue appstoreactions.ts-Datei

count: Observable<number>;

constructor(private store: Store<AppState>) { // 注入store
    var stream = store.pipe(select(&#39;count&#39;)); 
    // 从app.module.ts中获取count状态流
    stream.subscribe((res)=>{
          this.count = res;
      })
  }
Nach dem Login kopieren
Registrieren Sie sich im Stammmodul app.module.ts

import { Injectable } from &#39;@angular/core&#39;;
import { INCREMENT, DECREMENT, RESET } from &#39;./types&#39;;

@Injectable()
export class CounterAction{
    // Add=function(){}
    Add(){
        return { type: INCREMENT }
    }
}

// 就只这样导出是不行的
// export function Add1(){
//     return { type: INCREMENT }
// }
Nach dem Login kopieren
Verwenden Sie in der Komponente – article.component.ts

    import {CounterAction} from &#39;./store/actions&#39;;
    
    ... 
    
    providers: [CounterAction],
    Nach dem Login kopieren

  1. Für weitere Programmierung -bezogenes Wissen finden Sie unter:
  2. Programmieren lernen! !

      Das obige ist der detaillierte Inhalt vonAngular verwendet ngrx/store für die Statusverwaltung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Erklärung dieser Website
    Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

    Heiße KI -Werkzeuge

    Undresser.AI Undress

    Undresser.AI Undress

    KI-gestützte App zum Erstellen realistischer Aktfotos

    AI Clothes Remover

    AI Clothes Remover

    Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

    Undress AI Tool

    Undress AI Tool

    Ausziehbilder kostenlos

    Clothoff.io

    Clothoff.io

    KI-Kleiderentferner

    AI Hentai Generator

    AI Hentai Generator

    Erstellen Sie kostenlos Ai Hentai.

    Heißer Artikel

    R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
    4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Beste grafische Einstellungen
    4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
    4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    WWE 2K25: Wie man alles in Myrise freischaltet
    1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

    Heiße Werkzeuge

    Notepad++7.3.1

    Notepad++7.3.1

    Einfach zu bedienender und kostenloser Code-Editor

    SublimeText3 chinesische Version

    SublimeText3 chinesische Version

    Chinesische Version, sehr einfach zu bedienen

    Senden Sie Studio 13.0.1

    Senden Sie Studio 13.0.1

    Leistungsstarke integrierte PHP-Entwicklungsumgebung

    Dreamweaver CS6

    Dreamweaver CS6

    Visuelle Webentwicklungstools

    SublimeText3 Mac-Version

    SublimeText3 Mac-Version

    Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

    So installieren Sie Angular unter Ubuntu 24.04 So installieren Sie Angular unter Ubuntu 24.04 Mar 23, 2024 pm 12:20 PM

    Angular.js ist eine frei zugängliche JavaScript-Plattform zum Erstellen dynamischer Anwendungen. Es ermöglicht Ihnen, verschiedene Aspekte Ihrer Anwendung schnell und klar auszudrücken, indem Sie die Syntax von HTML als Vorlagensprache erweitern. Angular.js bietet eine Reihe von Tools, die Sie beim Schreiben, Aktualisieren und Testen Ihres Codes unterstützen. Darüber hinaus bietet es viele Funktionen wie Routing und Formularverwaltung. In dieser Anleitung wird erläutert, wie Angular auf Ubuntu24 installiert wird. Zuerst müssen Sie Node.js installieren. Node.js ist eine JavaScript-Ausführungsumgebung, die auf der ChromeV8-Engine basiert und es Ihnen ermöglicht, JavaScript-Code auf der Serverseite auszuführen. In Ub sein

    Detaillierte Erläuterung des Angular Learning State Managers NgRx Detaillierte Erläuterung des Angular Learning State Managers NgRx May 25, 2022 am 11:01 AM

    Dieser Artikel vermittelt Ihnen ein detailliertes Verständnis des Angular-Statusmanagers NgRx und stellt Ihnen die Verwendung von NgRx vor. Ich hoffe, er wird Ihnen hilfreich sein!

    Eine kurze Analyse der Verwendung des Monaco-Editors in Angular Eine kurze Analyse der Verwendung des Monaco-Editors in Angular Oct 17, 2022 pm 08:04 PM

    Wie verwende ich den Monaco-Editor in Angular? Der folgende Artikel dokumentiert die Verwendung des Monaco-Editors in Angular, der kürzlich in einem Unternehmen verwendet wurde. Ich hoffe, dass er für alle hilfreich sein wird!

    Ein Artikel über serverseitiges Rendering (SSR) in Angular Ein Artikel über serverseitiges Rendering (SSR) in Angular Dec 27, 2022 pm 07:24 PM

    Kennen Sie Angular Universal? Es kann dazu beitragen, dass die Website eine bessere SEO-Unterstützung bietet!

    Wie man PHP und Angular für die Frontend-Entwicklung verwendet Wie man PHP und Angular für die Frontend-Entwicklung verwendet May 11, 2023 pm 04:04 PM

    Mit der rasanten Entwicklung des Internets wird auch die Front-End-Entwicklungstechnologie ständig verbessert und iteriert. PHP und Angular sind zwei Technologien, die in der Frontend-Entwicklung weit verbreitet sind. PHP ist eine serverseitige Skriptsprache, die Aufgaben wie die Verarbeitung von Formularen, die Generierung dynamischer Seiten und die Verwaltung von Zugriffsberechtigungen übernehmen kann. Angular ist ein JavaScript-Framework, mit dem Single-Page-Anwendungen entwickelt und komponentenbasierte Webanwendungen erstellt werden können. In diesem Artikel erfahren Sie, wie Sie PHP und Angular für die Frontend-Entwicklung verwenden und wie Sie diese kombinieren

    Eine kurze Analyse unabhängiger Komponenten in Angular und deren Verwendung Eine kurze Analyse unabhängiger Komponenten in Angular und deren Verwendung Jun 23, 2022 pm 03:49 PM

    Dieser Artikel führt Sie durch die unabhängigen Komponenten in Angular, wie Sie eine unabhängige Komponente in Angular erstellen und wie Sie vorhandene Module in die unabhängige Komponente importieren. Ich hoffe, er wird Ihnen hilfreich sein!

    Winkelkomponenten und ihre Anzeigeeigenschaften: Nicht-Block-Standardwerte verstehen Winkelkomponenten und ihre Anzeigeeigenschaften: Nicht-Block-Standardwerte verstehen Mar 15, 2024 pm 04:51 PM

    Das Standardanzeigeverhalten für Komponenten im Angular-Framework gilt nicht für Elemente auf Blockebene. Diese Designwahl fördert die Kapselung von Komponentenstilen und ermutigt Entwickler, bewusst zu definieren, wie jede Komponente angezeigt wird. Durch explizites Festlegen der CSS-Eigenschaft display kann die Anzeige von Angular-Komponenten vollständig gesteuert werden, um das gewünschte Layout und die gewünschte Reaktionsfähigkeit zu erreichen.

    Was soll ich tun, wenn das Projekt zu groß ist? Wie teilt man Angular-Projekte sinnvoll auf? Was soll ich tun, wenn das Projekt zu groß ist? Wie teilt man Angular-Projekte sinnvoll auf? Jul 26, 2022 pm 07:18 PM

    Das Angular-Projekt ist zu groß. Wie kann man es sinnvoll aufteilen? Der folgende Artikel zeigt Ihnen, wie Sie Angular-Projekte sinnvoll aufteilen. Ich hoffe, er ist hilfreich für Sie!

    See all articles