Hi everyone! I'm the author of code.mu :)
I'd love to chat with my non-Russian audience. I'm looking for your feedback on the site and the translation quality. Let's chat:)
⊗jsrxPmRDPAD 26 of 57 menu

Redux में action ऑब्जेक्ट के लिए डेटा तैयार करना

हाल ही में हमने आपके साथ बात की थी कि फ़ंक्शन createSlice एक ही आर्ग्युमेंट की अपेक्षा करता है जब action.payload बनाया जाता है। एक तरफ तो यह इसके उपयोग को आसान बनाता है, दूसरी तरफ action ऑब्जेक्ट की सामग्री तैयार करने के लिए अतिरिक्त कदमों की आवश्यकता हो सकती है।

आइए हमारे उत्पादों वाले एप्लिकेशन को खोलें, और उसमें NewProductForm.jsx फ़ाइल खोलें। निम्नलिखित कोड लाइन पर ध्यान दें:

dispatch(productAdded({ id: nanoid(), name, desc, price, amount }))

यहाँ हम payload ऑब्जेक्ट को सीधे React कंपोनेंट में ही बना रहे हैं और इसे एक्शन productAdded में पास कर रहे हैं। लेकिन क्या होगा अगर हमें ऐसा ही एक्शन कई कंपोनेंट्स से भेजना पड़े या फिर उसे बनाने की लॉजिक जटिल हो जाए? सिद्धांत रूप में, हमारे कंपोनेंट को इस बात से कोई फर्क नहीं पड़ना चाहिए कि इस एक्शन के लिए payload में ऑब्जेक्ट कैसा दिखता है। साथ ही, कोड की लगातार नकल हमें स्वीकार्य नहीं है।

ये समस्याएं फिर से हल करने में हमारी मदद कर सकता है हमारा प्रसिद्ध createSlice, क्योंकि रिड्यूसर लिखते समय यह हमें कॉलबैक फ़ंक्शन prepare का उपयोग करने की अनुमति देता है, जिसमें विभिन्न प्रकार की लॉजिक लिखी जा सकती है, रैंडम नंबर जेनरेट किए जा सकते हैं आदि। ऐसे में रिड्यूसर फील्ड का मान निम्नलिखित ऑब्जेक्ट के रूप में दर्शाया जा सकता है:

{reducer, prepare}

आइए हमारी productsSlice.js फ़ाइल खोलें और रिड्यूसर productAdded के लिए कोड बदलें। अब कोड का यह हिस्सा:

productAdded(state, action) { state.push(action.payload) },

हम इसे निम्नलिखित में बदल देंगे, जिसमें फ़ंक्शन reducer store में स्टेट को अपडेट करने का काम करेगा, और prepare - payload ऑब्जेक्ट वापस करेगा जनरेट किए गए id और हमारे अन्य डेटा के साथ:

productAdded: { reducer(state, action) { state.push(action.payload) }, prepare(name, desc, price, amount) { return { payload: { id: nanoid(), name, desc, price, amount, }, } }, },

चूंकि अब हम id जेनरेट करेंगे यहाँ, कंपोनेंट में नहीं, आइए nanoid को इम्पोर्ट में जोड़ें:

import { createSlice, nanoid } from '@reduxjs/toolkit'

अंत में, बदलाव करते हैं NewProductForm.jsx में। इसके बजाय लाइन का:

dispatch(productAdded({ id: nanoid(), name, desc, price, amount }))

हमारे पास ऐसी लाइन होगी, जिसमें हम बस अल्पविराम से अपने आवश्यक डेटा पास करेंगे (इस फ़ाइल में nanoid को इम्पोर्ट से हटाना न भूलें):

dispatch(productAdded(name, desc, price, amount))

आइए एप्लिकेशन चलाएँ, फिर एक नया उत्पाद बनाएँ और सुनिश्चित करें कि हमने कुछ भी खराब नहीं किया है।

अपने छात्रों वाला एप्लिकेशन खोलें। StudentsSlice.js फ़ाइल में अपने रिड्यूसर studentAdded को इस तरह से फिर से लिखें, कि वह {reducer, prepare} ऑब्जेक्ट के रूप में हो, जैसा पाठ में दिखाया गया है।

NewStudentForm.jsx फ़ाइल में संबंधित बदलाव करें, जैसा पाठ में दिखाया गया है। एप्लिकेशन चलाएँ और सुनिश्चित करें, कि सब कुछ पहले की तरह काम कर रहा है।

हिन्दी
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
हम साइट के कार्य, विश्लेषण और व्यक्तिगतकरण के लिए कुकीज़ का उपयोग करते हैं। डेटा प्रसंस्करण गोपनीयता नीति के अनुसार किया जाता है।
सभी स्वीकार करें कॉन्फ़िगर करें अस्वीकार करें