⊗jsrtPmRtAL 42 of 47 menu

React Router में सक्रिय लिंक को हाइलाइट करना

मान लीजिए, हमने अपने एप्लिकेशन में कुछ उत्पाद जोड़े हैं और प्रत्येक उत्पाद को देख रहे हैं। हमें कैसे पता चलेगा कि हम किस उत्पाद के पेज पर हैं? आइए सूची में इस उत्पाद को हाइलाइट करें, उदाहरण के लिए मोटे फ़ॉन्ट और भूरे रंग से, और यदि लिंक अभी भी लोड हो रहा है, तो भूरे रंग से।

शुरुआत करने के लिए होम पेज पर जाएं, सूची में 4 उत्पाद जोड़ें और उनमें से प्रत्येक के लिए डेटा दर्ज करें। उन्हें कोई भी नाम दें।

सक्रिय लिंक को हाइलाइट करने में हमें NavLink कंपोनेंट मदद करेगा, यह Link कंपोनेंट का एक प्रकार है जो डेटा की स्थिति के बारे में जानता है। आमतौर पर इसका उपयोग नेविगेशन मेनू बनाते समय किया जाता है।

आइए root.jsx खोलें और NavLink इम्पोर्ट करें (Link के इम्पोर्ट को हटाना न भूलें, नहीं तो React एरर दे सकता है, क्योंकि हम अब इसका उपयोग नहीं कर रहे हैं):

import { NavLink } from 'react-router-dom';

फिर लेआउट में Link कंपोनेंट को NavLink से बदलें:

<NavLink key={product.id} to={`products/${product.id}`}> {product.name ? product.name : <i>unnamed</i>} </NavLink>

और इसे className प्रॉप्स दें, तथा सशर्त लॉजिक का उपयोग करें। यदि पेज लोड हो गया है, तो लिंक सक्रिय स्थिति में चला जाएगा, यदि लोड हो रहा है, तो लोडिंग स्थिति में, और यदि कुछ भी नहीं हो रहा है, तो पहले जैसा ही रहेगा। इसके आधार पर लिंक का क्लास बदल जाएगा:

<NavLink key={product.id} to={`products/${product.id}`} className={({ isActive, isPending }) => isActive ? 'active' : isPending ? 'loading' : '' } > {product.name ? product.name : <i>Unnamed</i>} </NavLink>

अब हमें अपनी css फ़ाइल में active और loading क्लासेस के लिए स्टाइल्स जोड़ने बाकी हैं:

a.active { font-weight: bold; color: brown; } a.loading { color: gray; }

हो गया! और अब सूची में उत्पादों पर क्लिक करके देखें।

पिछले पाठों के असाइनमेंट में आपके द्वारा बनाए गए एप्लिकेशन को लें। पाठ की सामग्री का उपयोग करके, इसमें छात्रों की सूची के लिए सक्रिय लिंक हाइलाइटेशन लागू करें ताकि यह स्पष्ट हो सके कि उपयोगकर्ता वर्तमान में किस छात्र का डेटा देख रहा है।

हिन्दी
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
हम साइट के कार्य, विश्लेषण और व्यक्तिगतकरण के लिए कुकीज़ का उपयोग करते हैं। डेटा प्रसंस्करण गोपनीयता नीति के अनुसार किया जाता है।
सभी स्वीकार करें कॉन्फ़िगर करें अस्वीकार करें