⊗jsrxPmRDMDO 30 of 57 menu

Redux-এ স্লাইস থেকে ডেটা পুনরায় ব্যবহার করা

গত ক্লাসে আমরা পণ্য যোগ করার ফর্মে বিক্রেতা নির্বাচনের জন্য একটি ড্রপডাউন মেনু সহ আরও একটি ফিল্ড যোগ করেছি, যিনি এটি তালিকাভুক্ত করেন। ধরা যাক, এখন আমাদের এই তথ্যটি অ্যাপ্লিকেশনের আরও কয়েকটি জায়গায় প্রদর্শন করতে হবে। এর জন্য আমরা প্রতিবার কোড ডুপ্লিকেট করব না, বরং কেবল একটি আলাদা কম্পোনেন্ট তৈরি করব, যেখানে আমরা স্লাইস থেকে ডেটা নিষ্কাশন করব এবং সেগুলি অ্যাপ্লিকেশনের সেই অংশগুলিতে প্রদর্শন করব যেখানে আমাদের প্রয়োজন।

আমাদের পণ্য সহ অ্যাপ্লিকেশনটি খুলুন। এখন products ফোল্ডারে আরও একটি ফাইল তৈরি করা যাক SellerOfProd.jsx। শুরুতে useSelector হুকটি ইম্পোর্ট করি, যার সাহায্যে আমরা প্রয়োজনীয় পণ্য সহ স্লাইসটি পাব:

import { useSelector } from 'react-redux'

তারপর store থেকে প্রয়োজনীয় পণ্যটি নিষ্কাশন করি বিক্রেতার id অনুযায়ী, যা আমরা আমাদের নতুন কম্পোনেন্টে props হিসেবে পাঠাব:

export const SellerOfProd = ({ sellerId }) => { const seller = useSelector((state) => state.sellers.find((seller) => seller.id === sellerId) ) }

এবং যদি এমন বিক্রেতা থাকে, আমরা তার নাম ফেরত দেব, আর যদি না থাকে, তাহলে 'unknown' ফেরত দেব:

return <span>by {seller ? seller.name : 'unknown'}</span>

এখন আমাদের নতুন কম্পোনেন্টটি ProductsList.jsx-এ ইম্পোর্ট করা যাক এবং ProductsList ফাংশনে পণ্যের নামের শিরোনামের পরেই এটি বসাই। আপনি দেখতে পাচ্ছেন, আমরা এটিকে props হিসাবে id পাঠিয়েছি:

<SellerOfProd sellerId={product.seller} />

এখন,如果我们 আমাদের অ্যাপ্লিকেশন চালু করি, একটি নতুন পণ্য যোগ করি এবং তালিকায় এটি খুঁজে পাই, তাহলে আমরা দেখতে পাব যে এর একটি বিক্রেতা রয়েছে, এবং অ্যাপ্লিকেশন শুরুতে স্বয়ংক্রিয়ভাবে যোগ করা পণ্যগুলির জন্য 'unknown' থাকবে।

একটি ছোট বিচ্যুতি: যদি আপনার VS Code এডিটরে eslint sellerId-এ আপত্তি করে, কিন্তু অ্যাপ্লিকেশন কাজ করে, তাহলে আপনি এটিকে暂时 উপেক্ষা করতে পারেন বা আপনার অ্যাপ্লিকেশনের .eslintrc.cjs ফাইলটি খুলে rules-এ "react/prop-types": "off" যোগ করতে পারেন।

স্বভাবতই, আমরা চাই বিক্রেতার তথ্য পণ্যের পৃষ্ঠাতেও যোগ করতে। এর জন্য ProductPage-এর লেআউটে পণ্যের নামের শিরোনামের পরে আবার এই লাইনটি বসাই এবং পরীক্ষা করে দেখি যে সব কাজ করছে:

<SellerOfProd sellerId={product.seller} />

আপনার শিক্ষার্থীদের নিয়ে অ্যাপ্লিকেশনটি খুলুন। পাঠের উপাদানটি অধ্যয়ন করে, students ফোল্ডারে TeacherForStudent কম্পোনেন্টের জন্য একটি ফাইল তৈরি করুন। ফলস্বরূপ কম্পোনেন্টটিকে অবশ্যই শিক্ষকের পূর্ণ নাম ফেরত দিতে হবে, এবং পাশের বন্ধনীতে তিনি যে বিষয় পড়ান। প্রয়োজনীয় শিক্ষক useSelector হুক ব্যবহার করে খুঁজে বের করুন। যদি এই শিক্ষার্থীর জন্য শিক্ষক না থাকে, তাহলে 'anonym' আউটপুট দিন।

পূর্ববর্তী কাজ থেকে প্রাপ্ত কম্পোনেন্ট ব্যবহার করে প্রতিটি শিক্ষার্থীর জন্য শিক্ষকের ডেটা শিক্ষার্থীদের তালিকা সহ পৃষ্ঠায় আউটপুট দিন।

পূর্ববর্তী কাজের মতোই করুন, কিন্তু একটি আলাদা শিক্ষার্থীর পৃষ্ঠার জন্য।

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