ReactJS - फ्लक्स का उपयोग करना

इस अध्याय में, हम सीखेंगे कि रिएक्ट एप्लिकेशन में फ्लक्स पैटर्न को कैसे लागू किया जाए। हम इस्तेमाल करेंगेReduxढांचा। इस अध्याय का लक्ष्य कनेक्ट करने के लिए आवश्यक प्रत्येक टुकड़े का सबसे सरल उदाहरण प्रस्तुत करना हैRedux तथा React

चरण 1 - Redux स्थापित करें

हम के माध्यम से Redux स्थापित करेंगे command prompt खिड़की।

C:\Users\username\Desktop\reactApp>npm install --save react-redux

चरण 2 - फ़ाइलें और फ़ोल्डर बनाएँ

इस चरण में, हम अपने लिए फोल्डर और फाइल्स बनाएंगे actions, reducers, तथा components। जब हम इसके साथ हो जाते हैं, तो यह फ़ोल्डर की संरचना कैसी दिखती है।

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

चरण 3 - क्रिया

क्रियाएँ जावास्क्रिप्ट ऑब्जेक्ट हैं जो उपयोग करते हैं typeसंपत्ति को उस डेटा के बारे में सूचित करने के लिए जिसे स्टोर में भेजा जाना चाहिए। हम परिभाषित कर रहे हैंADD_TODOकार्रवाई जो हमारी सूची में नई वस्तु जोड़ने के लिए उपयोग की जाएगी। addTodo फ़ंक्शन एक एक्शन क्रिएटर है जो हमारी कार्रवाई लौटाता है और सेट करता है id हर निर्मित वस्तु के लिए।

कार्यों / actions.js

export const ADD_TODO = 'ADD_TODO'

let nextTodoId = 0;

export function addTodo(text) {
   return {
      type: ADD_TODO,
      id: nextTodoId++,
      text
   };
}

चरण 4 - रिड्यूसर

जबकि कार्रवाई केवल अनुप्रयोग में परिवर्तन को ट्रिगर करती है, reducersउन परिवर्तनों को निर्दिष्ट करें। हम प्रयोग कर रहे हैंswitch एक के लिए खोज करने के लिए बयान ADD_TODOकार्रवाई। रिड्यूसर एक ऐसा फंक्शन है जो दो पैरामीटर लेता है (state तथा action) एक अद्यतन स्थिति की गणना और वापस करने के लिए।

पहला फ़ंक्शन एक नया आइटम बनाने के लिए उपयोग किया जाएगा, जबकि दूसरा उस आइटम को सूची में धकेल देगा। अंत की ओर, हम उपयोग कर रहे हैंcombineReducers हेल्पर फंक्शन जहां हम भविष्य में उपयोग होने वाले किसी भी नए रिड्यूसर को जोड़ सकते हैं।

reducers / reducers.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

चरण 5 - स्टोर

स्टोर एक ऐसी जगह है जो ऐप की स्थिति रखती है। आपके पास रिड्यूसर होने के बाद स्टोर बनाना बहुत आसान है। हम दुकान की संपत्ति पास कर रहे हैंprovider तत्व, जो हमारे मार्ग घटक को लपेटता है।

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
)

चरण 6 - रूट घटक

Appघटक एप का मूल घटक है। केवल रूट घटक को एक रिडक्स के बारे में पता होना चाहिए। नोटिस करने के लिए महत्वपूर्ण हिस्सा हैconnect फ़ंक्शन जो हमारे रूट घटक को जोड़ने के लिए उपयोग किया जाता है App को store

यह फ़ंक्शन लेता है selectएक तर्क के रूप में कार्य करें। चयन समारोह राज्य को स्टोर से लेता है और सहारा देता है (visibleTodos) जो हम अपने घटकों में उपयोग कर सकते हैं।

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);

चरण 7 - अन्य घटक

इन घटकों को redux के बारे में पता नहीं होना चाहिए।

घटकों / 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 = ''
   }
}

घटकों / Todo.js

import React, { Component, PropTypes } from 'react'

export default class Todo extends Component {
   render() {
      return (
         <li>
            {this.props.text}
         </li>
      )
   }
}

घटकों / 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>
      )
   }
}

जब हम ऐप शुरू करेंगे, तो हम अपनी सूची में आइटम जोड़ पाएंगे।