Redux - कोर अवधारणाओं

हमें लगता है कि हमारे आवेदन की स्थिति को एक सादे वस्तु द्वारा वर्णित किया गया है initialState जो इस प्रकार है -

const initialState = {
   isLoading: false,
   items: [],
   hasError: false
};

आपके एप्लिकेशन का प्रत्येक कोड इस स्थिति को बदल नहीं सकता है। राज्य को बदलने के लिए, आपको एक कार्रवाई भेजने की आवश्यकता है।

एक्शन क्या है?

एक क्रिया एक सादे वस्तु है जो एक प्रकार की संपत्ति के साथ परिवर्तन का कारण बनाने के इरादे का वर्णन करती है। इसके पास एक प्रकार की संपत्ति होनी चाहिए जो बताती है कि किस प्रकार की कार्रवाई की जा रही है। कार्रवाई की कमान इस प्रकार है -

return {
   type: 'ITEMS_REQUEST', //action type
   isLoading: true //payload information
}

Reducer नामक फ़ंक्शन द्वारा क्रियाओं और राज्यों को एक साथ रखा जाता है। परिवर्तन का कारण बनाने के इरादे से एक कार्रवाई को भेजा जाता है। यह परिवर्तन reducer द्वारा किया जाता है। Reducer, Redux में राज्यों को बदलने का एकमात्र तरीका है, जो इसे अधिक पूर्वानुमानित, केंद्रीकृत और डीबग करने योग्य बनाता है। एक Reducer फ़ंक्शन जो 'ITEMS_REQUEST' कार्रवाई को संभालता है, इस प्रकार है -

const reducer = (state = initialState, action) => { //es6 arrow function
   switch (action.type) {
      case 'ITEMS_REQUEST':
         return Object.assign({}, state, {
            isLoading: action.isLoading
         })
      default:
         return state;
   }
}

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

हम चर्चा करेंगे कि हम रीड्यूसर को कैसे विभाजित कर सकते हैं और बाद में इस ट्यूटोरियल में स्टोर के साथ जोड़ सकते हैं।

Redux घटक निम्नानुसार हैं -