Redux - रिएक्ट उदाहरण

यहाँ प्रतिक्रिया और Redux आवेदन का एक छोटा सा उदाहरण है। आप छोटे ऐप विकसित करने का भी प्रयास कर सकते हैं। वृद्धि या कमी काउंटर के लिए नमूना कोड नीचे दिया गया है -

यह रूट फाइल है जो स्टोर के निर्माण और हमारी प्रतिक्रिया ऐप घटक को प्रस्तुत करने के लिए जिम्मेदार है।

/src/index.js

import React from 'react'
import { render } from 'react-dom'
import { Provider } from 'react-redux'
import { createStore } from 'redux';
import reducer from '../src/reducer/index'
import App from '../src/App'
import './index.css';

const store = createStore(
   reducer,
   window.__REDUX_DEVTOOLS_EXTENSION__ && 
   window.__REDUX_DEVTOOLS_EXTENSION__()
)
render(
   <Provider store = {store}>
      <App />
   </Provider>, document.getElementById('root')
)

यह हमारी प्रतिक्रिया का मूल घटक है। यह एक बच्चे के रूप में काउंटर कंटेनर घटक प्रदान करने के लिए जिम्मेदार है।

/src/app.js

import React, { Component } from 'react';
import './App.css';
import Counter from '../src/container/appContainer';

class App extends Component {
   render() {
      return (
         <div className = "App">
            <header className = "App-header">
               <Counter/>
            </header>
         </div>
      );
   }
}
export default App;

निम्नलिखित कंटेनर घटक है जो Redux के घटक को प्रतिक्रिया देने के लिए जिम्मेदार है -

/container/counterContainer.js

import { connect } from 'react-redux'
import Counter from '../component/counter'
import { increment, decrement, reset } from '../actions';

const mapStateToProps = (state) => {
   return {
      counter: state
   };
};
const mapDispatchToProps = (dispatch) => {
   return {
      increment: () => dispatch(increment()),
      decrement: () => dispatch(decrement()),
      reset: () => dispatch(reset())
   };
};
export default connect(mapStateToProps, mapDispatchToProps)(Counter);

नीचे दिए गए प्रतिक्रिया घटक को देखने के भाग के लिए जिम्मेदार है -

/component/counter.js
import React, { Component } from 'react';
class Counter extends Component {
   render() {
      const {counter,increment,decrement,reset} = this.props;
      return (
         <div className = "App">
            <div>{counter}</div>
            <div>
               <button onClick = {increment}>INCREMENT BY 1</button>
            </div>
            <div>
               <button onClick = {decrement}>DECREMENT BY 1</button>
            </div>
            <button onClick = {reset}>RESET</button>
         </div>
      );
   }
}
export default Counter;

एक्शन क्रिएट करने के लिए जिम्मेदार एक्शन क्रिएटर निम्नलिखित हैं -

/actions/index.js
export function increment() {
   return {
      type: 'INCREMENT'
   }
}
export function decrement() {
   return {
      type: 'DECREMENT'
   }
}
export function reset() {
   return { type: 'RESET' }
}

नीचे, हमने reducer फ़ाइल के लिए कोड की लाइन दिखाई है जो Redux में राज्य को अपडेट करने के लिए ज़िम्मेदार है।

reducer/index.js
const reducer = (state = 0, action) => {
   switch (action.type) {
      case 'INCREMENT': return state + 1
      case 'DECREMENT': return state - 1
      case 'RESET' : return 0 default: return state
   }
}
export default reducer;

प्रारंभ में, एप्लिकेशन निम्नानुसार दिखता है -

जब मैं दो बार वेतन वृद्धि पर क्लिक करता हूं, तो आउटपुट स्क्रीन नीचे दिखाई जाएगी -

जब हम इसे एक बार घटाते हैं, तो यह निम्न स्क्रीन दिखाता है -

और रीसेट एप्लिकेशन को प्रारंभिक अवस्था में वापस ले जाएगा जो काउंटर वैल्यू है। यह नीचे दिखाया गया है -

आइए समझते हैं कि जब पहली वेतन वृद्धि की कार्रवाई होती है तो Redux dev टूल्स के साथ क्या होता है -

एप्लिकेशन की स्थिति को उस समय ले जाया जाएगा जब केवल वेतन वृद्धि की कार्रवाई को भेज दिया जाता है और बाकी कार्यों को छोड़ दिया जाता है।

हम अपने आप से एक छोटे से टोडो ऐप को एक असाइनमेंट के रूप में विकसित करने के लिए प्रोत्साहित करते हैं और Redux टूल को बेहतर तरीके से समझते हैं।