⊗jsrxPmATADR 49 of 57 menu

Redux-এ অনুরোধের ডুপ্লিকেশন দূর করা

এই পাঠটি আমাদের জন্য উপযোগী হবে যদি, অ্যাপ্লিকেশন চালু করার সময়, ডেটা অনুরোধ পাঠানো ডুপ্লিকেট হয়, এবং তারপর একই id সহ পণ্যগুলির জোড়া আসে, এবং ফলস্বরূপ, ব্রাউজার কনসোলে ভয়ানক লাল সতর্কবার্তা প্রকাশিত হয়।

এর কারণটি React 18 সংস্করণ এবং তার উপরের সংস্করণে ডেভেলপমেন্ট মোডে (dev), React.StrictMode ব্যবহার করার সময় কম্পোনেন্ট মাউন্ট করার বিশেষত্বে রয়েছে (তারা বলে, প্রোডাকশন মোডে এটি নিয়ে সব ঠিক আছে)। প্রথমে কম্পোনেন্টটি সংযুক্ত হয়, তারপর সংযোগ বিচ্ছিন্ন হয় এবং আবার সংযুক্ত হয়। সেইজন্য অনুরোধ দুবার পাঠানো হয়।

সম্ভবত, যখন আপনি এই উপাদানটি অধ্যয়ন করবেন, React-এর এই ডাবল মাউন্টিং ইতিমধ্যেই কোনোভাবে পরিবর্তিত হয়ে যাবে। আমরা গভীরে যাব না, বরং সহজভাবে React হুক useRef ব্যবহার করব, যা আমাদের এই অসঙ্গতি এড়াতে সাহায্য করবে।

আসুন আমাদের পণ্য সহ অ্যাপ্লিকেশনটি খুলি, এবং এতে ProductsList.jsx ফাইলটি খুলি। এতে useRef হুকটি ইম্পোর্ট করি:

import { useEffect, useRef } from 'react'

এবং এখন useEffect সহ নিম্নলিখিত কোড ব্লকটি একটু পরিবর্তন করি:

useEffect(() => { if (productStatus === 'idle') { dispatch(fetchProducts()) } }, [productStatus, dispatch])

প্রথমে useRef-এর জন্য একটি নতুন ভেরিয়েবল dataFetch প্রবর্তন করি। প্রাথমিকভাবে এর current প্রপার্টি false-এ সেট করি। যদি অ্যাপ্লিকেশন ইতিমধ্যেই চালু হয়ে থাকে এবং সেই অনুযায়ী, অনুরোধ ইতিমধ্যেই পাঠানো হয়ে থাকে, তাহলে current প্রপার্টিটি ইতিমধ্যেই true হবে, যার মানে আমরা কেবল ফাংশন থেকে বের হয়ে আসব এবং ডেটার পুনরায় অনুরোধ করা হবে না। সুতরাং, উপরে উল্লিখিত কোডের অংশটি এখন এইরকম হবে:

const dataFetch = useRef(false) useEffect(() => { if (dataFetch.current) return dataFetch.current = true if (productStatus === 'idle') { dispatch(fetchProducts()) } }, [productStatus, dispatch])

এখন আবার আমাদের অ্যাপ্লিকেশন চালু করি এবং স্বস্তি সহ লক্ষ্য করি কনসোলে লাল সতর্কবার্তাগুলির অবলুপ্তি, এবং ডুপ্লিকেট ছাড়াই পণ্যের তালিকা দেখি, এখন সেখানে 8টি রয়েছে, ঠিক যেমন আমরা সার্ভারে পরিকল্পনা করেছিলাম। এখন Redux DevTools-এ একশনগুলি, যেগুলো অনুরোধের সময় তৈরি হয়, সেগুলি আবার পুনরাবৃত্তি হয় না।

আপনার শিক্ষার্থীদের সাথে অ্যাপ্লিকেশনটি খুলুন, এবং এতে StudentsList.jsx ফাইলটি খুলুন। পাঠের উপাদান অনুসারে ডাবল অনুরোধের সমস্যাটি দূর করুন, যদি আপনার কাছে এমনটি থেকে থাকে।

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