⊗jsrxPmRDEP 23 of 57 menu

Redux store-এ পণ্যের তথ্য পরিবর্তন

আমরা পণ্য যোগ করতে শিখেছি, কিন্তু কি হবে যদি আমরা একটি পণ্যের তথ্য পরিবর্তন করতে চাই? এই এবং পরবর্তী পাঠে এটি কীভাবে করা যায় তা দেখা যাক।

আমাদের পণ্য অ্যাপ্লিকেশনটি খুলুন এবং productsSlice.js ফাইলে যান। শুরু করা যাক এই থেকে যে আমাদের products স্লাইসের জন্য আরেকটি রিডিউসার লিখতে হবে, যা একটি পণ্য আপডেট করার সময় ট্রিগার হবে। এটির নাম দিন productUpdated এবং productAdded রিডিউসারের পরে reducers ফিল্ডে এটি যোগ করুন। এছাড়াও তাত্ক্ষণিকভাবে এটিকে প্যারামিটার হিসেবে state এবং action পাস করুন, যা ভিত্তি করে, যেমন আমরা মনে রাখি, রিডিউসার কাজ করে:

reducers: { productAdded(state, action) { state.push(action.payload) }, productUpdated(state, action) {}, },

এখন চিন্তা করা যাক, আমাদের কী কী তথ্যের প্রয়োজন হবে একটি পণ্য আপডেট করার জন্য। প্রথমত - এটি হল id, এর মাধ্যমে আমরা store-এ আমাদের আগ্রহের পণ্যটি খুঁজে পেতে সক্ষম হব। বাকি তথ্য - নাম, বিবরণ, মূল্য এবং পরিমাণ পরিবর্তনের জন্য আমাদের কাছে থাকবে। এই সমস্ত মান আমরা action অবজেক্টের payload প্রপার্টি থেকে পাব, যা আমাদের কাছে আসবে, এবং যদি আমরা এটি হাতে লিখতাম, তবে এটি নীচে দেখানো হিসাবে দেখাত। লক্ষ্য করুন যে প্রত্যাশিত মান payload প্রপার্টির - একটি আর্গুমেন্ট, তাই আমরা এখানে একটি অবজেক্ট পাস করব (এটি নিয়ে আমরা পরে আলোচনা করব):

{ type: 'products/productUpdated', payload: {id, name, desc, price, amount} }

মূল puntos খুঁজে বের করে, এখন আমরা productUpdated-এর জন্য কোড লিখতে পারি কার্লি ব্র্যাকেটের মধ্যে। প্রথমে action অবজেক্ট থেকে পরিবর্তিত তথ্য নেওয়া যাক:

productUpdated(state, action) { const { id, name, desc, price, amount } = action.payload },

এখন আমরা প্রাপ্ত id অনুসারে সেই পণ্যটি খুঁজে পাব, যেটি পরিবর্তন করা প্রয়োজন:

productUpdated(state, action) { const { id, name, desc, price, amount } = action.payload const desiredProduct = state.find(product => product.id === id) },

যদি এমন পণ্য store-এ পাওয়া যায়, তবে আমরা এর তথ্য নতুন মান দিয়ে প্রতিস্থাপন করব:

productUpdated(state, action) { const { id, name, desc, price, amount } = action.payload const desiredProduct = state.find(product => product.id === id) if (desiredProduct) { desiredProduct.name = name desiredProduct.desc = desc desiredProduct.price = price desiredProduct.amount = amount } },

আমাদের শুধু action creatorটি রপ্তানি করতে হবে কম্পোনেন্টে ব্যবহারের জন্য, যা createSlice আমাদের জন্য তৈরি করবে। চলুন এটি ফাইলের শেষে রপ্তানির সাথে যোগ করি, বিদ্যমান productAdded-এর পাশাপাশি:

export const { productAdded, productUpdated } = productsSlice.actions

আপনার শিক্ষার্থীদের অ্যাপ্লিকেশনটি খুলুন। পাঠের উপাদান অধ্যয়ন করে, studentsSlice.js ফাইলে productsSlice-এর জন্য আরেকটি রিডিউসার লিখুন, যা ব্যবহারকারী দ্বারা পরিবর্তন করা হলে store-এ শিক্ষার্থীর তথ্য আপডেট করবে। এটির নাম দিন studentUpdated

আর এই ক্ষেত্রে আপনার action অবজেক্টটি কেমন দেখাত? উত্তর হিসেবে এর কোড পাঠান।

ফাইলের শেষে প্রাপ্ত action creator studentUpdated রপ্তানি করুন।

বাংলা
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
আমরা সাইট পরিচালনা, বিশ্লেষণ এবং ব্যক্তিগতকরণের জন্য কুকি ব্যবহার করি। ডেটা প্রক্রিয়াকরণ গোপনীয়তা নীতি অনুযায়ী করা হয়।
সব গ্রহণ করুন কনফিগার করুন প্রত্যাখ্যান করুন