Redux - शुद्ध कार्य

एक फ़ंक्शन एक प्रक्रिया है जो तर्कों को इनपुट करती है, और कुछ आउटपुट लौटा मूल्य के रूप में जाना जाता है। एक फ़ंक्शन को शुद्ध कहा जाता है यदि यह निम्नलिखित नियमों का पालन करता है -

  • एक फ़ंक्शन समान तर्कों के लिए एक ही परिणाम देता है।

  • इसके मूल्यांकन का कोई दुष्प्रभाव नहीं है, अर्थात, यह इनपुट डेटा को परिवर्तित नहीं करता है।

  • स्थानीय और वैश्विक चर का कोई म्यूटेशन नहीं।

  • यह वैश्विक चर की तरह बाहरी स्थिति पर निर्भर नहीं करता है।

आइए एक फ़ंक्शन का उदाहरण लेते हैं जो फ़ंक्शन के इनपुट के रूप में पारित मूल्य के दो गुना रिटर्न देता है। सामान्य तौर पर, इसे f, (x) => x * 2 के रूप में लिखा जाता है। यदि किसी फ़ंक्शन को तर्क मान 2 के साथ कहा जाता है, तो आउटपुट 4, एफ (2) => 4 होगा।

नीचे बताए अनुसार हम जावास्क्रिप्ट में फ़ंक्शन की परिभाषा लिखते हैं -

const double = x => x*2; // es6 arrow function
console.log(double(2));  // 4

Here, double is a pure function.

Redux में तीन सिद्धांतों के अनुसार, Redux में शुद्ध कार्य अर्थात रेड्यूसर द्वारा परिवर्तन किए जाने चाहिए। अब, एक सवाल उठता है कि क्यों एक reducer एक शुद्ध कार्य होना चाहिए।

मान लीजिए, आप एक क्रिया को भेजना चाहते हैं जिसका प्रकार है 'ADD_TO_CART_SUCCESS' ऐड टू कार्ट बटन पर क्लिक करके अपने शॉपिंग कार्ट एप्लिकेशन में एक आइटम जोड़ें।

चलिए मान लेते हैं कि reducer आपके कार्ट में एक आइटम जोड़ रहा है जैसा कि नीचे दिया गया है -

const initialState = {
   isAddedToCart: false;
}
const addToCartReducer = (state = initialState, action) => { //es6 arrow function
   switch (action.type) {
      case 'ADD_TO_CART_SUCCESS' :
         state.isAddedToCart = !state.isAddedToCart; //original object altered
         return state;
      default:
         return state;
   }
}
export default addToCartReducer ;

हमें लगता है, isAddedToCart एक राज्य वस्तु पर एक संपत्ति है जो आपको यह तय करने की अनुमति देता है कि एक बूलियर मूल्य वापस करके आइटम के लिए 'कार्ट में जोड़ें' बटन को कब अक्षम किया जाए? ‘true or false’। यह उपयोगकर्ता को एक ही उत्पाद को कई बार जोड़ने से रोकता है। अब, एक नई वस्तु को वापस करने के बजाय, हम ऊपर की तरह राज्य पर isAddedToCart प्रोप को म्यूट कर रहे हैं। अब अगर हम गाड़ी में एक आइटम जोड़ने की कोशिश करते हैं, तो कुछ भी नहीं होता है। कार्ट में जोड़ें बटन अक्षम नहीं होगा।

इस व्यवहार का कारण इस प्रकार है -

Redux दोनों वस्तुओं की मेमोरी लोकेशन द्वारा पुरानी और नई वस्तुओं की तुलना करता है। यदि कोई परिवर्तन हुआ है तो यह reducer से एक नई वस्तु की उम्मीद करता है। और यह भी उम्मीद करता है कि अगर कोई बदलाव नहीं होता है तो पुरानी वस्तु को वापस ले लिया जाएगा। इस मामले में, यह वही है। इस कारण से, Redux मानता है कि कुछ भी नहीं हुआ है।

तो, Redux में शुद्ध कार्य करने के लिए Reducer का होना आवश्यक है। निम्नलिखित म्यूटेशन के बिना इसे लिखने का एक तरीका है -

const initialState = {
   isAddedToCart: false;
}
const addToCartReducer = (state = initialState, action) => { //es6 arrow function
   switch (action.type) {
      case 'ADD_TO_CART_SUCCESS' :
         return {
            ...state,
            isAddedToCart: !state.isAddedToCart
         }
      default:
         return state;
   }
}
export default addToCartReducer;