⊗jsrxPmATDT 54 of 57 menu

Redux-এ thunk ব্যবহার করে ডেটা প্রেরণ

গত ক্লাসে, আমরা আমাদের নকল সার্ভারে POST অনুরোধ প্রক্রিয়া করা নিয়ে আলোচনা করেছিলাম। আসুন এখন একটি thunk ফাংশন লিখি যা সার্ভারে অনুরোধ প্রেরণ করবে।

আসুন আমাদের পণ্য অ্যাপ্লিকেশনটি খুলি, এবং সেখানে productsSlice.js ফাইলটি খুলি। এখন thunk fetchProducts-এর পরে, আমরা createAsyncThunk ব্যবহার করে একটি thunk addProduct তৈরি করব:

export const addProduct = createAsyncThunk()

createAsyncThunk-এ প্রথম প্যারামিটার হিসেবে আমরা 'products/addProduct' পাস করব, এবং দ্বিতীয়টি একটি অ্যাসিঙ্ক্রোনাস কলব্যাক, যা একটি নতুন পণ্যের ডেটা সহ একটি অবজেক্ট গ্রহণ করবে:

export const addProduct = createAsyncThunk( 'products/addProduct', async (newProduct) => {} )

এই কলব্যাকের কোডে, আমরা ক্লায়েন্টকে কল করব, একে পাথ এবং পণ্য সহ অবজেক্ট প্যারামিটার হিসেবে পাস করে, এবং তারপর রেসপন্সের ডেটা রিটার্ন করব:

export const addProduct = createAsyncThunk( 'products/addProduct', async (newProduct) => { const response = await client.post('/fakeServer/products', newProduct) return response.data } )

এখন নিচের কোডে productsSlice-এর জন্য reducers ফিল্ডটি দেখি। আগে আমরা রিডিউসার productAdded ব্যবহার করে একটি নতুন পণ্য যোগ করতাম, যার মধ্যে আমাদের reducer এবং prepare মেথড ছিল। এখন আমরা সার্ভারে প্রয়োজনীয় ডেটা জেনারেট করছি এবং thunk নিয়ে কাজ করছি, তাই এখান থেকে সম্পূর্ণভাবে রিডিউসার productAdded কোড থেকে সরিয়ে দেব। তারপর extraReducers মেথডে (এর কোডের শেষে) আরও একটি অতিরিক্ত রিডিউসার যোগ করব, যা সফল অনুরোধের ক্ষেত্রে products স্লাইসে action-এর payload থেকে সরাসরি একটি নতুন পণ্য যোগ করবে (মনে রাখবেন, এই ধরনের কোড শুধুমাত্র createSlice-এর অনন্য ক্ষমতার কারণে সম্ভব):

.addCase(addProduct.fulfilled, (state, action) => { state.products.push(action.payload) })

হ্যাঁ, উপায় দ্বারা, ইম্পোর্ট লাইন থেকে nanoid সরাতে ভুলবেন না, এবং ফাইলের শেষে এক্সপোর্ট করা একশনগুলোর তালিকা থেকে productAdded সরাতে ভুলবেন না।

আপনার শিক্ষার্থীদের অ্যাপ্লিকেশনটি খুলুন। সেখানে studentsSlice.js ফাইলটি খুলুন। createAsyncThunk ব্যবহার করে আরও একটি thunk addStudent তৈরি করুন, যা পাঠে দেখানো হয়েছে এরকম একটি নতুন শিক্ষার্থী যোগ করতে সার্ভারে একটি POST অনুরোধ প্রেরণ করবে।

এরপরে নিচে studentsSlice-এর জন্য পরিবর্তনগুলি সন্নিবেশ করুন: reducers প্রপার্টিতে সম্পূর্ণভাবে রিডিউসার studentAdded সরিয়ে দিন। এবং extraReducers ফিল্ডে একটি অতিরিক্ত রিডিউসার যোগ করুন, যা সফল অনুরোধের ক্ষেত্রে students স্লাইসে action-এর payload থেকে একটি নতুন শিক্ষার্থী যোগ করবে, যেমনটি পাঠে দেখানো হয়েছে।

বাংলা
AfrikaansAzərbaycanБългарскиБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
আমরা সাইট পরিচালনা, বিশ্লেষণ এবং ব্যক্তিগতকরণের জন্য কুকি ব্যবহার করি। ডেটা প্রক্রিয়াকরণ গোপনীয়তা নীতি অনুযায়ী করা হয়।
সব গ্রহণ করুন কনফিগার করুন প্রত্যাখ্যান করুন