


Informationen zum Verbinden von React-Redux in React und Redux (ausführliches Tutorial)
Dieser Artikel stellt hauptsächlich die Verbindung zwischen React und Redux vor, React-Redux. Der Herausgeber findet ihn recht gut, daher werde ich ihn jetzt mit Ihnen teilen und als Referenz verwenden. Folgen wir dem Editor, um einen Blick darauf zu werfen
Ich habe mich schon früher mit React-bezogenen Dingen beschäftigt und habe ein SPA-Projekt in der Hand, also bin ich bereit, Redux auszuprobieren. Redux selbst hat keine Verbindung zu React. Es handelt sich um ein allgemeines Javascript-App-Modul, das für die App-Statusverwaltung verwendet wird. Um Redux in einem React-Projekt zu verwenden, besteht eine bessere Möglichkeit darin, die React-Redux-Bibliothek zum Verbinden zu verwenden. Das bedeutet, dass diese beiden Bibliotheken ohne React-Redux keine gewisse Kapselung bieten wissenschaftliche Art der Codeorganisation, die es uns ermöglicht, Redux im React-Code komfortabler zu verwenden.
Vorher habe ich React-Redux nur durch die Redux-Dokumentation kennengelernt. Nach einer gewissen Zeit der Übung werde ich mir den Quellcode ansehen und einige relevante Zusammenfassungen erstellen. Die npm-Version des Codes, die ich mir ansehe, ist v4.0.0, was bedeutet, dass die verwendete React-Version 0.14.x ist.
react-redux bietet zwei Schlüsselmodule: Provider und Connect.
Provider
Das Provider-Modul wird als Container der gesamten App verwendet. Es ist mit einer weiteren Ebene über Ihrem ursprünglichen App-Container verpackt Einfach, was bedeutet, dass der Redux-Store als Requisiten akzeptiert und als eines der Attribute des Kontexts deklariert wird. Nach der Deklaration von contextTypes können Unterkomponenten bequem über this.context.store auf den Store zugreifen. Unsere Komponenten müssen dies jedoch normalerweise nicht tun. Der Store wird für die folgende Verbindung in den Kontext gestellt.
Dies ist ein Beispiel für die Verwendung von Provider:
// config app root const history = createHistory() const root = ( <Provider store={store} key="provider"> <Router history={history} routes={routes} /> </Provider> ) // render ReactDOM.render( root, document.getElementById('root') )
connect
Dieses Modul ist eine echte Verbindung zwischen Redux und React, genau wie sein Name auch namens connect.
Überlegen Sie zunächst, wie Redux funktioniert: Zuerst wird ein Status im Store beibehalten, wir lösen eine Aktion aus und dann aktualisiert der Reduzierer den Status basierend auf dieser Aktion.
wird unserer React-Anwendung zugeordnet. Der im Store verwaltete Status ist unser App-Status. Eine React-Komponente dient als Ansichtsebene und erledigt zwei Aufgaben: Rendern und Reagieren auf Benutzervorgänge. Connect besteht also darin, die erforderlichen Daten im Store als Requisiten zum Rendern an die React-Komponente zu übergeben und den Aktionsersteller zu umschließen, um eine Aktion als Reaktion auf Benutzeroperationen auszulösen.
Okay, werfen wir einen detaillierten Blick auf die Funktionsweise des Verbindungsmoduls. Beginnen wir mit der Verwendung. Die API lautet wie folgt:
connect([mapStateToProps], [mapDispatchToProps], [mergeProps], [options])
mapStateToProps ist eine Funktion, und der Rückgabewert stellt den Status dar, der in Requisiten zusammengeführt werden muss. Der Standardwert ist () => ({}), was bedeutet, dass nichts übergeben wird.
(state, props) => ({ }) // 通常会省略第二个参数
mapDispatchToProps kann eine Funktion sein, die nur die Requisiten zusammenführen muss. Der actionCreator sollte hier mit der Funktion „bindActionCreators“ gepackt werden.
(dispatch, props) => ({ // 通常会省略第二个参数 ...bindActionCreators({ ...ResourceActions }, dispatch) })
Bequemer ist, dass Sie ein Objekt zu diesem Zeitpunkt direkt in eine Funktion umwandeln können. Diese Funktion ist genau die gleiche wie im obigen Beispiel.
mergeProps wird zum Anpassen des Zusammenführungsprozesses verwendet. Der Wert von parentProps ist der Props der Komponente selbst. Sie können feststellen, dass derselbe Name auf den Props der Komponente erscheint. es wird überschrieben.
(stateProps, dispatchProps, parentProps) => ({ ...parentProps, ...stateProps, ...dispatchProps })
Optionen haben zwei Schalter: pure gibt an, ob die Optimierung aktiviert werden soll. Die Standardeinstellung ist true, um der darin enthaltenen Komponente eine Referenz zu geben über die getWrappedInstance-Methode. Der Standardwert ist false.
connect gibt eine Funktion zurück, die den Konstruktor einer React-Komponente als Verbindungsobjekt akzeptiert und letztendlich den Konstruktor der verbundenen Komponente zurückgibt.
Dann ein paar Fragen:
Wie reagieren React-Komponenten auf Store-Änderungen?
Warum führt Connect einige Requisiten selektiv zusammen, anstatt den gesamten Status direkt zu übergeben?
Was bedeutet pure Optimierung?
Wir rufen die von connect Connector zurückgegebene Funktion auf. Sie gibt nicht nur die ursprüngliche Komponente zurück, sondern lauscht auch intern auf Änderungen Ermöglichen Sie den von ihr umhüllten Komponenten, auf Speicheränderungen zu reagieren:
trySubscribe() { if (shouldSubscribe && !this.unsubscribe) { this.unsubscribe = this.store.subscribe(::this.handleChange) this.handleChange() } } handleChange () { this.setState({ storeState: this.store.getState() }) }
Aber normalerweise verbinden wir eine Containerkomponente, die nicht den gesamten App-Status trägt, aber unser Handler reagiert auf alle Statusänderungen, also was wir Optimierungsbedarf besteht darin, dass wir bei einer Änderung des StoreState die entsprechende React-Komponente nur dann neu rendern, wenn wir wirklich von diesem Teil der Zustandsänderung abhängig sind. Von welchem Teil sind wir also wirklich abhängig? Es wird über mapStateToProps und mapDispatchToProps abgerufen.
Die spezifische Optimierungsmethode besteht darin, ShouldComponentUpdate einzuchecken, wenn sich die eigenen Requisiten der Komponente oder das Ergebnis von MapStateToProps-Änderungen oder das Ergebnis von MapDispatchToProps-Änderungen ändern .
Also für einen bestimmten Reduzierer:
export default (state = {}, action) => { return { ...state } // 返回的是一个新的对象,可能会使组件reRender // return state // 可能不会使得组件reRender }
Achten Sie außerdem beim Herstellen einer Verbindung darauf, den Status oder die ActionCreators, die Sie wirklich benötigen, den Requisiten zuzuordnen, um unnötige Leistungseinbußen zu vermeiden.
Schließlich haben wir laut Connect-API herausgefunden, dass wir die ES7-Dekoratorfunktion verwenden können, um sie an die Schreibmethode von React ES6 anzupassen:
@connect( state => ({ user: state.user, resource: state.resource }), dispatch => ({ ...bindActionCreators({ loadResource: ResourceActions.load }, dispatch) }) ) export default class Main extends Component { }
Das Obige ist, was ich für alle zusammengestellt habe Ich hoffe, dass es in Zukunft für alle hilfreich sein wird.
Verwandte Artikel:
Zusammenfassung des JS-Sortieralgorithmus
So erstellen Sie einen Kegel mit JS+Canvas
So implementieren Sie Routing in Vue -router Lazy Loading
So implementieren Sie das Breakpoint-Debugging von TS-Dateien in Angular2
So implementieren Sie das Scrollen von Webseiten nach oben
Ordnerstrukturkonfiguration in Vue
Das obige ist der detaillierte Inhalt vonInformationen zum Verbinden von React-Redux in React und Redux (ausführliches Tutorial). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



So erstellen Sie eine Echtzeit-Chat-Anwendung mit React und WebSocket Einführung: Mit der rasanten Entwicklung des Internets hat die Echtzeitkommunikation immer mehr Aufmerksamkeit auf sich gezogen. Live-Chat-Apps sind aus dem modernen Sozial- und Arbeitsleben nicht mehr wegzudenken. In diesem Artikel wird erläutert, wie Sie mit React und WebSocket eine einfache Echtzeit-Chat-Anwendung erstellen, und es werden spezifische Codebeispiele bereitgestellt. 1. Technische Vorbereitung Bevor wir mit der Erstellung einer Echtzeit-Chat-Anwendung beginnen, müssen wir die folgenden Technologien und Tools vorbereiten: React: eine zum Erstellen

React-Leitfaden zur Front-End- und Back-End-Trennung: So erreichen Sie die Front-End- und Back-End-Entkopplung und die unabhängige Bereitstellung. Es sind spezifische Codebeispiele erforderlich. In der heutigen Webentwicklungsumgebung ist die Front-End- und Back-End-Trennung zu einem Trend geworden. Durch die Trennung von Front-End- und Back-End-Code kann die Entwicklungsarbeit flexibler und effizienter gestaltet und die Zusammenarbeit im Team erleichtert werden. In diesem Artikel wird erläutert, wie Sie mithilfe von React eine Front-End- und Back-End-Trennung erreichen und so die Ziele der Entkopplung und unabhängigen Bereitstellung erreichen. Zuerst müssen wir verstehen, was Front-End- und Back-End-Trennung ist. Im traditionellen Webentwicklungsmodell sind Front-End und Back-End gekoppelt

So erstellen Sie mit React und Flask einfache und benutzerfreundliche Webanwendungen. Einführung: Mit der Entwicklung des Internets werden die Anforderungen an Webanwendungen immer vielfältiger und komplexer. Um den Anforderungen der Benutzer an Benutzerfreundlichkeit und Leistung gerecht zu werden, wird es immer wichtiger, moderne Technologie-Stacks zum Aufbau von Netzwerkanwendungen zu verwenden. React und Flask sind zwei sehr beliebte Frameworks für die Front-End- und Back-End-Entwicklung, und sie arbeiten gut zusammen, um einfache und benutzerfreundliche Webanwendungen zu erstellen. In diesem Artikel erfahren Sie, wie Sie React und Flask nutzen

So erstellen Sie eine zuverlässige Messaging-Anwendung mit React und RabbitMQ Einführung: Moderne Anwendungen müssen zuverlässiges Messaging unterstützen, um Funktionen wie Echtzeitaktualisierungen und Datensynchronisierung zu erreichen. React ist eine beliebte JavaScript-Bibliothek zum Erstellen von Benutzeroberflächen, während RabbitMQ eine zuverlässige Messaging-Middleware ist. In diesem Artikel wird erläutert, wie Sie React und RabbitMQ kombinieren, um eine zuverlässige Messaging-Anwendung zu erstellen, und es werden spezifische Codebeispiele bereitgestellt. RabbitMQ-Übersicht:

React Responsive Design Guide: So erzielen Sie adaptive Front-End-Layouteffekte Mit der Beliebtheit mobiler Geräte und der steigenden Nachfrage der Benutzer nach Multi-Screen-Erlebnissen ist Responsive Design zu einem der wichtigsten Aspekte in der modernen Front-End-Entwicklung geworden. React, eines der derzeit beliebtesten Frontend-Frameworks, bietet eine Fülle von Tools und Komponenten, die Entwicklern dabei helfen, adaptive Layouteffekte zu erzielen. In diesem Artikel werden einige Richtlinien und Tipps zur Implementierung von responsivem Design mit React vorgestellt und spezifische Codebeispiele als Referenz bereitgestellt. Fle mit React

React-Code-Debugging-Leitfaden: So finden und beheben Sie Front-End-Fehler schnell. Einführung: Bei der Entwicklung von React-Anwendungen stoßen Sie häufig auf eine Vielzahl von Fehlern, die zum Absturz der Anwendung oder zu fehlerhaftem Verhalten führen können. Daher ist die Beherrschung von Debugging-Fähigkeiten eine wesentliche Fähigkeit für jeden React-Entwickler. In diesem Artikel werden einige praktische Techniken zum Auffinden und Beheben von Front-End-Fehlern vorgestellt und spezifische Codebeispiele bereitgestellt, um Lesern dabei zu helfen, Fehler in React-Anwendungen schnell zu finden und zu beheben. 1. Auswahl der Debugging-Tools: In Re

ReactRouter-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung Mit der Popularität von Single-Page-Anwendungen ist das Front-End-Routing zu einem wichtigen Bestandteil geworden, der nicht ignoriert werden kann. Als beliebteste Routing-Bibliothek im React-Ökosystem bietet ReactRouter umfangreiche Funktionen und benutzerfreundliche APIs, wodurch die Implementierung des Front-End-Routings sehr einfach und flexibel ist. In diesem Artikel wird die Verwendung von ReactRouter vorgestellt und einige spezifische Codebeispiele bereitgestellt. Um ReactRouter zuerst zu installieren, benötigen wir

So verwenden Sie React und Google BigQuery zum Erstellen schneller Datenanalyseanwendungen. Einführung: Im heutigen Zeitalter der Informationsexplosion ist die Datenanalyse zu einem unverzichtbaren Bindeglied in verschiedenen Branchen geworden. Unter anderem ist die Entwicklung schneller und effizienter Datenanalyseanwendungen für viele Unternehmen und Einzelpersonen zum Ziel geworden. In diesem Artikel wird erläutert, wie Sie mit React und Google BigQuery eine schnelle Datenanalyseanwendung erstellen, und es werden detaillierte Codebeispiele bereitgestellt. 1. Übersicht React ist ein Werkzeug zum Erstellen
