⊗jsrtPmCpPS 85 of 112 menu

React-এ চাইল্ড কম্পোনেন্টে স্টেট পাঠানো

ধরুন আমাদের কাছে পণ্যের একটি অ্যারে দেওয়া আছে:

const initProds = [ {id: id(), name: 'product1', cost: 100}, {id: id(), name: 'product2', cost: 200}, {id: id(), name: 'product3', cost: 300}, ];

ধরুন এই অ্যারেটি Products কম্পোনেন্টে অবস্থিত। এই পণ্যগুলোকে কম্পোনেন্টের স্টেটে লিখি:

function Products() { const [prods, setProds] = useState(initProds); }

এখন আসুন একটি লুপ দিয়ে পণ্যগুলো পড়ি এবং সেগুলো কিছু মার্কআপে আউটপুট করি:

function Products() { const [prods, setProds] = useState(initProds); const items = prods.map(prod => { return <div key={prod.id}> name: <span>{prod.name}</span>, cost: <span>{prod.cost}</span> </div>; }); return <div> {items} </div>; }

আপনি যেমন দেখতে পাচ্ছেন, আমাদের map লুপের বিষয়বস্তু যথেষ্ট জটিল, বিশেষ করে যদি ভবিষ্যতে পণ্যের মার্কআপ বড় হয়ে যায়। এমন জটিলতা পড়া, বোঝা এবং কোড রক্ষণাবেক্ষণ কঠিন করে তোলে।

পণ্য প্রদর্শনের জন্য দায়ী কোডটিকে একটি আলাদা কম্পোনেন্টে স্থানান্তর করা ভাল হবে। এর নাম দিই Product। এখানে আমাদের কম্পোনেন্টের কোড:

function Product({ name, cost }) { return <div> name: <span>{name}</span>, cost: <span>{cost}</span> </div>; }

এখন Products কম্পোনেন্টের ভিতরে map লুপে Product চাইল্ড কম্পোনেন্ট ব্যবহার করা যাক:

function Products() { const [prods, setProds] = useState(initProds); const items = prods.map(prod => { return <Product key ={prod.id} name={prod.name} cost={prod.cost} />; }); return <div> {items} </div>; }

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

প্রযুক্তিগতভাবে, এটি দেখা যাচ্ছে যে প্যারেন্ট কম্পোনেন্টের ডেটা সহ একটি স্টেট আছে, এবং চাইল্ড কম্পোনেন্টগুলি প্রপ্স আকারে এই ডেটা পায় এবং সেগুলো আমাদের প্রয়োজনীয় উপায়ে প্রদর্শন করে।

Users কম্পোনেন্টের স্টেটে নিম্নলিখিত অ্যারে দেওয়া আছে:

const initUsers = [ {id: id(), name: 'user1', surname: 'surn1', age: 30}, {id: id(), name: 'user2', surname: 'surn2', age: 31}, {id: id(), name: 'user3', surname: 'surn3', age: 32}, ];

এই অ্যারেটি একটি লুপ দিয়ে পড়ুন এবং সকল ব্যবহারকারীকে স্ক্রিনে আউটপুট করুন। ব্যবহারকারী প্রদর্শনের জন্য একটি পৃথক কম্পোনেন্ট User তৈরি করুন।

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