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:)
⊗jsrxPmATGS 51 of 57 menu

Redux में विक्रेताओं के डेटा प्राप्त करना

चलिए अपने उत्पादों वाले एप्लिकेशन को चलाते हैं। हम देखते हैं कि उत्पाद कार्ड में विक्रेताओं की जानकारी प्रदर्शित नहीं हो रही है। आइए उन्हें सर्वर से प्राप्त करें और यह डेटा दिखाएं। इसके लिए हमें पहले से परिचित कार्यों के अनुक्रम को करना होगा।

शुरुआत के लिए server.js फ़ाइल खोलें। handlers ऐरे को ढूंढें और उसमें GET-अनुरोध का एक और हैंडलर जोड़ें (उत्पादों के लिए GET हैंडलिंग के बाद)। जैसा कि आप देख रहे हैं, यह लगभग समान है:

http.get('/fakeServer/sellers', async () => { await delay(ARTIFICIAL_DELAY_MS) return HttpResponse.json(db.seller.getAll()) }),

हमने सर्वर पर अनुरोध को संसाधित कर दिया है। अगले चरण में, हमें sellersSlice.js फ़ाइल में सर्वर से डेटा प्राप्त करने के लिए एक thunk लिखना होगा। इसके लिए इसमें client और createAsyncThunk आयात करें:

import { createSlice, createAsyncThunk } from '@reduxjs/toolkit' import { client } from '../../api/client'

अब हम विक्रेताओं को सर्वर से प्राप्त करेंगे, इसलिए उन्हें initialState से हटा दें, केवल खाली कोष्ठक छोड़ दें:

const initialState = []

और फिर sellersSlice फ़ंक्शन से पहले हमारा thunk fetchSellers बनाएं। क्लाइंट को हम वह पथ पास करेंगे जो हमने सर्वर पर निर्दिष्ट किया है:

export const fetchSellers = createAsyncThunk( 'sellers/fetchSellers', async () => { const response = await client.get('/fakeServer/sellers') return response.data } )

हमें केवल sellersSlice के लिए एक अतिरिक्त रिड्यूसर बनाना बाकी है। यहां हम सफल अनुरोध के प्रसंस्करण तक सीमित रहेंगे। fetchSellers द्वारा जेनरेट किए गए सभी एक्शन, fetchProducts के एक्शन के समान होंगे:

const sellersSlice = createSlice({ name: 'sellers', initialState, reducers: {}, extraReducers(builder) { builder.addCase(fetchSellers.fulfilled, (state, action) => { return action.payload }) }, })

मैं आपको याद दिला दूं कि पिछली बार उत्पाद प्राप्त करते समय, हमने वर्तमान स्टेट के मान को बदल दिया था। यहां हमने थोड़ा अलग तरीका अपनाया और बस एक नया मान लौटा दिया, क्योंकि createSlice में भी ऐसा करना संभव है। इस तरह हमने दो लक्ष्यों को प्राप्त किया। सबसे पहले, हमें डेटा मिल गया, और दूसरी बात, अब हमें यह गारंटी है कि विक्रेताओं की सूची में कुछ और नहीं जुड़ेगा, क्योंकि हमने पूरी तरह से स्लाइस को action.payload मान से लिख दिया है।

अपने छात्रों वाला एप्लिकेशन खोलें। इसमें server.js फ़ाइल खोलें, handlers ऐरे में शिक्षकों के लिए GET-अनुरोध का एक और हैंडलर जोड़ें।

और अब teachersSlice.js फ़ाइल खोलें। initialState को पाठ में दिखाए अनुसार खाली ऐरे बनाएं। studentsSlice फ़ंक्शन से पहले thunk fetchTeachers लिखें।

createSlice फ़ंक्शन में अतिरिक्त रिड्यूसर जोड़ें, सफल अनुरोध के प्रसंस्करण तक सीमित रहें।

हिन्दी
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
हम साइट के कार्य, विश्लेषण और व्यक्तिगतकरण के लिए कुकीज़ का उपयोग करते हैं। डेटा प्रसंस्करण गोपनीयता नीति के अनुसार किया जाता है।
सभी स्वीकार करें कॉन्फ़िगर करें अस्वीकार करें