ReactJS - Verwenden von Flux
In diesem Kapitel erfahren Sie, wie Sie Flussmuster in React-Anwendungen implementieren. Wir werden verwendenReduxRahmen. Das Ziel dieses Kapitels ist es, das einfachste Beispiel für jedes Stück zu präsentieren, das zum Verbinden benötigt wirdRedux und React.
Schritt 1 - Installieren Sie Redux
Wir werden Redux über das installieren command prompt Fenster.
C:\Users\username\Desktop\reactApp>npm install --save react-redux
Schritt 2 - Dateien und Ordner erstellen
In diesem Schritt erstellen wir Ordner und Dateien für unsere actions, reducers, und components. Nachdem wir damit fertig sind, sieht die Ordnerstruktur so aus.
C:\Users\Tutorialspoint\Desktop\reactApp>mkdir actions
C:\Users\Tutorialspoint\Desktop\reactApp>mkdir components
C:\Users\Tutorialspoint\Desktop\reactApp>mkdir reducers
C:\Users\Tutorialspoint\Desktop\reactApp>type nul > actions/actions.js
C:\Users\Tutorialspoint\Desktop\reactApp>type nul > reducers/reducers.js
C:\Users\Tutorialspoint\Desktop\reactApp>type nul > components/AddTodo.js
C:\Users\Tutorialspoint\Desktop\reactApp>type nul > components/Todo.js
C:\Users\Tutorialspoint\Desktop\reactApp>type nul > components/TodoList.js
Schritt 3 - Aktionen
Aktionen sind JavaScript-Objekte, die verwendet werden typeEigenschaft, um über die Daten zu informieren, die an das Geschäft gesendet werden sollen. Wir definierenADD_TODOAktion, die zum Hinzufügen eines neuen Elements zu unserer Liste verwendet wird. DasaddTodo function ist ein Aktionsersteller, der unsere Aktion zurückgibt und eine setzt id für jeden erstellten Artikel.
Actions / Actions.js
export const ADD_TODO = 'ADD_TODO'
let nextTodoId = 0;
export function addTodo(text) {
return {
type: ADD_TODO,
id: nextTodoId++,
text
};
}
Schritt 4 - Reduzierstücke
Während Aktionen nur Änderungen in der App auslösen, wird die reducersGeben Sie diese Änderungen an. Wir benutzenswitch Anweisung zur Suche nach a ADD_TODOAktion. Der Reduzierer ist eine Funktion, die zwei Parameter akzeptiert (state und action), um einen aktualisierten Status zu berechnen und zurückzugeben.
Die erste Funktion wird verwendet, um ein neues Element zu erstellen, während die zweite Funktion dieses Element in die Liste überträgt. Gegen Ende verwenden wircombineReducers Hilfsfunktion, mit der wir neue Reduzierungen hinzufügen können, die wir möglicherweise in Zukunft verwenden werden.
Reduzierstücke / Reduzierstücke.js
import { combineReducers } from 'redux'
import { ADD_TODO } from '../actions/actions'
function todo(state, action) {
switch (action.type) {
case ADD_TODO:
return {
id: action.id,
text: action.text,
}
default:
return state
}
}
function todos(state = [], action) {
switch (action.type) {
case ADD_TODO:
return [
...state,
todo(undefined, action)
]
default:
return state
}
}
const todoApp = combineReducers({
todos
})
export default todoApp
Schritt 5 - Speichern
Der Store ist ein Ort, an dem der Status der App gespeichert ist. Es ist sehr einfach, ein Geschäft zu erstellen, sobald Sie Reduzierungen haben. Wir übergeben Ladenbesitz an dieprovider Element, das unsere Routenkomponente umschließt.
main.js
import React from 'react'
import { render } from 'react-dom'
import { createStore } from 'redux'
import { Provider } from 'react-redux'
import App from './App.jsx'
import todoApp from './reducers/reducers'
let store = createStore(todoApp)
let rootElement = document.getElementById('app')
render(
<Provider store = {store}>
<App />
</Provider>,
rootElement
)
Schritt 6 - Stammkomponente
Das AppKomponente ist die Stammkomponente der App. Nur die Root-Komponente sollte einen Redux kennen. Der wichtige Teil zu beachten ist dieconnect Funktion, die zum Verbinden unserer Root-Komponente verwendet wird App zum store.
Diese Funktion benötigt selectFunktion als Argument. Die Auswahlfunktion übernimmt den Status aus dem Geschäft und gibt die Requisiten zurück (visibleTodos), die wir in unseren Komponenten verwenden können.
App.jsx
import React, { Component } from 'react'
import { connect } from 'react-redux'
import { addTodo } from './actions/actions'
import AddTodo from './components/AddTodo.js'
import TodoList from './components/TodoList.js'
class App extends Component {
render() {
const { dispatch, visibleTodos } = this.props
return (
<div>
<AddTodo onAddClick = {text =>dispatch(addTodo(text))} />
<TodoList todos = {visibleTodos}/>
</div>
)
}
}
function select(state) {
return {
visibleTodos: state.todos
}
}
export default connect(select)(App);
Schritt 7 - Andere Komponenten
Diese Komponenten sollten sich des Redux nicht bewusst sein.
Komponenten / AddTodo.js
import React, { Component, PropTypes } from 'react'
export default class AddTodo extends Component {
render() {
return (
<div>
<input type = 'text' ref = 'input' />
<button onClick = {(e) => this.handleClick(e)}>
Add
</button>
</div>
)
}
handleClick(e) {
const node = this.refs.input
const text = node.value.trim()
this.props.onAddClick(text)
node.value = ''
}
}
Komponenten / Todo.js
import React, { Component, PropTypes } from 'react'
export default class Todo extends Component {
render() {
return (
<li>
{this.props.text}
</li>
)
}
}
Komponenten / TodoList.js
import React, { Component, PropTypes } from 'react'
import Todo from './Todo.js'
export default class TodoList extends Component {
render() {
return (
<ul>
{this.props.todos.map(todo =>
<Todo
key = {todo.id}
{...todo}
/>
)}
</ul>
)
}
}
Wenn wir die App starten, können wir Elemente zu unserer Liste hinzufügen.