Redux - प्रतिक्रिया को एकीकृत

पिछले अध्यायों में, हमने सीखा है कि Redux क्या है और यह कैसे काम करता है। आइए अब Redux के साथ व्यू भाग के एकीकरण की जाँच करें। आप Redux में किसी भी दृश्य परत को जोड़ सकते हैं। हम प्रतिक्रिया पुस्तकालय और Redux पर भी चर्चा करेंगे।

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

आइए चर्चा करते हैं कि यह Redux के साथ कैसे संभव है। Redux दो घटकों के साथ प्रतिक्रिया घटकों को बांधने के लिए अभिक्रिया-रिडक्स पैकेज प्रदान करता है जैसा कि नीचे दिया गया है -

  • Provider
  • Connect

प्रदाता शेष एप्लिकेशन को स्टोर उपलब्ध कराता है। कनेक्ट फ़ंक्शन स्टोर से कनेक्ट करने के लिए घटक की प्रतिक्रिया में मदद करता है, स्टोर की स्थिति में होने वाले प्रत्येक परिवर्तन का जवाब देता है।

हम पर एक नजर है root index.js फ़ाइल जो स्टोर बनाता है और एक प्रदाता का उपयोग करता है जो स्टोर को एक प्रतिक्रिया-रिडक्स ऐप में बाकी ऐप के लिए सक्षम बनाता है।

import React from 'react'
import { render } from 'react-dom'
import { Provider } from 'react-redux'
import { createStore, applyMiddleware } from 'redux';
import reducer from './reducers/reducer'
import thunk from 'redux-thunk';
import App from './components/app'
import './index.css';

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

जब भी किसी प्रतिक्रिया-रिडक्स ऐप में परिवर्तन होता है, तो mapStateToProps () कहा जाता है। इस फ़ंक्शन में, हम वास्तव में निर्दिष्ट करते हैं कि हमें अपनी प्रतिक्रिया घटक को किस राज्य को प्रदान करना है।

नीचे दिए गए कनेक्ट () फ़ंक्शन की सहायता से, हम घटक पर प्रतिक्रिया करने के लिए इन ऐप की स्थिति को जोड़ रहे हैं। कनेक्ट () एक उच्च क्रम फ़ंक्शन है जो घटक को पैरामीटर के रूप में लेता है। यह कुछ संचालन करता है और सही डेटा के साथ एक नया घटक देता है जिसे हमने अंततः निर्यात किया था।

MapStateToProps () की सहायता से, हम इन स्टोर स्टेट्स को हमारे रिएक्शन कंपोनेंट के प्रोप के रूप में प्रदान करते हैं। यह कोड कंटेनर घटक में लपेटा जा सकता है। मकसद डेटा लाने, चिंता प्रदान करने और पुन: प्रयोज्य जैसी चिंताओं को अलग करना है।

import { connect } from 'react-redux'
import Listing from '../components/listing/Listing' //react component
import makeApiCall from '../services/services' //component to make api call

const mapStateToProps = (state) => {
   return {
      items: state.items,
      isLoading: state.isLoading
   };
};
const mapDispatchToProps = (dispatch) => {
   return {
      fetchData: () => dispatch(makeApiCall())
   };
};
export default connect(mapStateToProps, mapDispatchToProps)(Listing);

सेवाओं में एक एपी कॉल करने के लिए एक घटक की परिभाषा। जे एस फ़ाइल इस प्रकार है -

import axios from 'axios'
import { itemsLoading, itemsFetchDataSuccess } from '../actions/actions'

export default function makeApiCall() {
   return (dispatch) => {
      dispatch(itemsLoading(true));
      axios.get('http://api.tvmaze.com/shows')
      .then((response) => {
         if (response.status !== 200) {
            throw Error(response.statusText);
         }
         dispatch(itemsLoading(false));
         return response;
      })
      .then((response) => dispatch(itemsFetchDataSuccess(response.data)))
   };
}

mapDispatchToProps () फ़ंक्शन एक पैरामीटर के रूप में प्रेषण फ़ंक्शन प्राप्त करता है और आपको कॉलबैक प्रॉप्स को सादे ऑब्जेक्ट के रूप में देता है जिसे आप अपने प्रतिक्रिया घटक में पास करते हैं।

यहां, आप अपनी प्रतिक्रिया सूची घटक में एक प्रस्ताव के रूप में fetchData का उपयोग कर सकते हैं, जो एपीआई कॉल करने के लिए एक कार्रवाई को भेजता है। mapDispatchToProps () को स्टोर करने के लिए एक्शन भेजने के लिए उपयोग किया जाता है। प्रतिक्रिया-रिडक्स में, घटक सीधे स्टोर तक नहीं पहुंच सकते हैं। कनेक्ट () का उपयोग करने का एकमात्र तरीका है।

आइए समझते हैं कि नीचे दिए गए आरेख के माध्यम से प्रतिक्रिया-रिडक्स कैसे काम करता है -

STORE - जावास्क्रिप्ट ऑब्जेक्ट के रूप में आपके सभी एप्लिकेशन स्टेट को संग्रहीत करता है

PROVIDER - भंडार उपलब्ध करता है

CONTAINER - एप्लिकेशन स्थिति प्राप्त करें और इसे घटकों के लिए एक प्रस्ताव के रूप में प्रदान करें

COMPONENT - उपयोगकर्ता दृश्य घटक के माध्यम से बातचीत करता है

ACTIONS - स्टोर में परिवर्तन का कारण बनता है, यह आपके ऐप की स्थिति को बदल भी सकता है और नहीं भी

REDUCER - केवल ऐप राज्य को बदलने का तरीका, राज्य और कार्रवाई को स्वीकार करें, और अपडेट की गई स्थिति।

हालाँकि, Redux एक स्वतंत्र लाइब्रेरी है और इसे किसी भी UI लेयर के साथ इस्तेमाल किया जा सकता है। प्रतिक्रिया-रिडक्स आधिकारिक Redux, प्रतिक्रिया के साथ यूआई बाइंडिंग है। इसके अलावा, यह एक अच्छी प्रतिक्रिया Redux ऐप संरचना को प्रोत्साहित करता है। रिएक्ट-रिडक्स आंतरिक रूप से प्रदर्शन अनुकूलन को लागू करता है, ताकि घटक फिर से प्रस्तुत होता है जब यह आवश्यक हो।

संक्षेप में, Redux को सबसे छोटा और सबसे तेज़ कोड लिखने के लिए डिज़ाइन नहीं किया गया है। यह एक अनुमानित राज्य प्रबंधन कंटेनर प्रदान करने का इरादा है। यह समझने में हमारी मदद करता है कि एक निश्चित स्थिति कब बदल गई, या डेटा कहां से आया।