⊗jsrtPmRtPR 47 of 47 menu

React Router-এ পাথবিহীন রুট

এই পাঠে আমরা পাথবিহীন রুটের আরও একটি দরকারী বৈশিষ্ট্য নিয়ে আলোচনা করব।

আপনি জানেন যে প্রতিটি রুট অবজেক্টের জন্য আপনি errorElement প্রপার্টি যোগ করতে পারেন এবং এর মান হিসেবে সেই এলিমেন্টটি সেট করতে পারেন যেটি আপনি ত্রুটি ঘটলে প্রদর্শন করতে চান।

কিন্তু যদি আমাদের জন্য errorElement সব রুটের জন্য একই হয়? অবশ্যই, প্রতিটির জন্য একই জিনিস লিখতে পারেন, অথবা আপনি পাথবিহীন রুট ব্যবহার করে, আমাদের আগ্রহের চাইল্ড রুটগুলিকে এটির মধ্যে র্যাপ করতে পারেন। তাহলে তাদের মধ্যে任何一个 ত্রুটি ঘটলে, আমাদের পাথবিহীন রুট সেগুলি ক্যাচ করবে এবং এর নিজস্ব errorElement প্রদর্শন করবে।

চলুন main.jsx ফাইলে যাই এবং আমাদের সব চাইল্ড রুটগুলিকে একটি পাথবিহীন রুট দিয়ে র্যাপ করি, সেগুলিকে এর চাইল্ড বানিয়ে (আবার এই রুটটি হবে রুট রুটের চাইল্ড), এটিতে errorElement প্রপার্টিও যোগ করতে ভুলবেন না:

const router = createBrowserRouter([ { path: '/', element: <Root />, errorElement: <ErrorPage404 />, loader: rootLoader, action: rootAction, children: [ { errorElement: <ErrorPage404 />, children: [ { index: true, element: <Index /> }, { path: 'products/:productId', element: <Product />, loader: productLoader, }, { path: 'products/:productId/edit', element: <EditProduct />, loader: editProductLoader, action: editAction, }, { path: 'products/:productId/delete', action: deleteAction, }, ], }, ], }, ]);

এখন এই কোডের কাজ কীভাবে পরীক্ষা করবেন? ত্রুটি নিক্ষেপ করার জন্য একটি লাইন যোগ করা যেতে পারে (পরীক্ষা করার পর এটিকে সরিয়ে ফেলতে ভুলবেন না)। উদাহরণস্বরূপ, চলুন পণ্য মুছে ফেলার রুটের action ফাংশনের প্রথম লাইন হিসেবে এটি যোগ করি, তাহলে পণ্য মুছতে尝试 করলে আমরা ত্রুটি দেখতে পাব:

export async function action({ params }) { throw new Error('error'); await deleteProduct(params.productId); return redirect('/'); }

এখন একটি পণ্য মুছতে尝试 করুন।

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

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