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.