⊗jsrtPmCpChPS 87 of 112 menu

React-এ প্যারেন্ট স্টেট চাইল্ড কম্পোনেন্টে পরিবর্তন করা

পূর্ববর্তী পাঠে, আমাদের ডেটা সহ স্টেট প্যারেন্ট কম্পোনেন্টে সংরক্ষণ করা ছিল, এবং চাইল্ড কম্পোনেন্টগুলি প্রপ্স的形式ে সেই ডেটা পেয়েছিল।

এখন ধরুন আমরা আমাদের পণ্যগুলি পরিবর্তন করতে চাই। উদাহরণস্বরূপ, একটি বাটন তৈরি করা যাক যা আমাদের পণ্যকে কার্টে রাখবে। শুরুতে আসুন আমাদের পণ্যের অ্যারেতে একটি ফিল্ড যোগ করি inCart, যা দেখাবে পণ্যটি কার্টে আছে কি না:

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

Products কম্পোনেন্টে, পণ্য সহ ট্যাগে আরও একটি অ্যাট্রিবিউট inCart যোগ করি:

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

আসুন চাইল্ড কম্পোনেন্ট Product-এ কার্ট সম্পর্কে তথ্য এবং কার্টে যোগ করার জন্য একটি বাটন তৈরি করি:

function Product({ id, name, cost, inCart }) { return <div> name: <span>{name}</span>, cost: <span>{cost}</span>, <span>{inCart ? 'in cart' : 'not in cart'}</span> <button>to cart</button> </div>; }

যোগ করা বাস্তবায়ন করি

React-এর নিয়ম অনুসারে, একটি কম্পোনেন্টের নিজস্ব প্রপ্স পরিবর্তন করা উচিত নয়। এর অর্থ চাইল্ড কম্পোনেন্ট নিজে থেকে inCart প্রপ্স পরিবর্তন করে নিজেকে কার্টে রাখতে পারে না। এটি সঠিক নয়।

সঠিক উপায় হবে প্যারেন্ট কম্পোনেন্টকে তার prods স্টেট পরিবর্তন করতে বলে, একটি নির্দিষ্ট পণ্যকে কার্টে রাখতে।

আসুন দেখি কিভাবে এটি করা হয়।

প্যারেন্ট কম্পোনেন্টে, আসুন একটি ফাংশন addToCart তৈরি করি, যা প্যারামিটার হিসাবে পণ্যের id নেয় এবং সেই পণ্যের জন্য inCart প্রপার্টি true-এ পরিবর্তন করে:

function addToCart(id) { setProds(prods.map(prod => { if (prod.id === id) { prod.inCart = true; } return prod; })); }

পণ্য সহ ট্যাগে, আমরা একটি অ্যাট্রিবিউট যোগ করব, যেখানে আমরা আমাদের তৈরি করা ফাংশনটি পাস করব, এবং এছাড়াও একটি অ্যাট্রিবিউট, যেখানে আমরা পণ্যের id পাস করব:

const items = prods.map(prod => { return <Product key ={prod.id} id ={prod.id} name ={prod.name} cost ={prod.cost} inCart ={prod.inCart} addToCart={addToCart} />; });

আপনি দেখতে পাচ্ছেন, কম্পোনেন্টের প্রপ্স-এ শুধুমাত্র কিছু ডেটা নয়, বরং ফাংশনও পাঠানো যায়।

Products ক্লাসের চূড়ান্ত কোড হবে নিম্নরূপ:

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

এখন চাইল্ড ক্লাসে আমাদের কাছে addToCart ফাংশনটি অ্যাক্সেসযোগ্য হবে। বাটনে ক্লিক করলে এই ফাংশনটি কল করি, এটিকে প্যারামিটার হিসাবে পণ্যের id পাস করে:

function Product({ id, name, cost, inCart, addToCart }) { return <div> name: <span>{name}</span>, cost: <span>{cost}</span>, <span>{inCart ? 'in cart' : 'not in cart'}</span> <button onClick={() => addToCart(id)}>to cart</button> </div>; }

এর ফলে, চাইল্ড কম্পোনেন্টে বাটনে ক্লিক করলে প্যারেন্টের ফাংশন কল হবে, যা প্যারেন্ট স্টেট পরিবর্তন করবে। প্যারেন্ট স্টেটের পরিবর্তন রি-রেন্ডারিং ঘটাবে এবং পরিবর্তিত প্রপ্স পাস করে আমাদের পণ্যকে পুনরায় রেন্ডার করবে।

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