اذهب إلى المحتوى
  • 0

ارتباط نشط باستخدام React-Router؟

Rayden Storm

السؤال

أنا أحاول استخدام  React-Router  وأواجه مشكلات ف حتى يكون أحد الروابط نشطًا. إذا قمت بالنقر فوق أي من علامات الارتباط ، فستبدأ العناصر النشطة في العمل. ومع ذلك ، أود أن يكون Home Link نشطًا بمجرد بدء التطبيق لأن هذا هو المكون الذي يتم تحميله في المسار /. هل هناك أي طريقة للقيام بذلك؟

const Router = () => (
  <Router>
    <Switch>
          <Route path="/about">
            <About />
          </Route>
          <Route path="/users">
            <Users />
          </Route>
          <Route path="/">
            <Home />
          </Route>
    </Switch>
  </Router>
)

 

رابط هذا التعليق
شارك على الشبكات الإجتماعية

Recommended Posts

  • 0

هناك جزئين لحل هذه المشكلة

  1. أن تستخدم exact الخاصة بالراوتر وذلك حتي تفتح الصفحة علي نفس ال Route الذي تكتبه فبدونها يتم اعتبار ( / ) من ال Route ( /about or /users ) أي عندما تريد الذهاب إلى ( home  ) يأخذك إلى About
    const Router = () => (
      <Router>
        <Switch>
              <Route exact path="/">
                <Home />
              </Route>
          
              <Route exact path="/about">
                <About />
              </Route>
          
              <Route exact path="/users">
                <Users />
              </Route>
    
        </Switch>
      </Router>
    )

     

  2. بعد تسجيل الدخول عليك بتوجيه التطبيق إلى صفحة ال home ويمكنك عملها عن طريق react-router history
     

    afterLogin = () => {
      history.push('/');
    }

     

رابط هذا التعليق
شارك على الشبكات الإجتماعية

  • 0

لكي تستعمل الروابط النشطه داخل ال navbar الخاص بالموقع وتستطيع أن تعطي لهم تنسيق معين في حالة وجعل ال  Home Link نشطًا بمجرد بدء التطبيق لابد من إستعمال المكون NavLink المرفق ب react-router داخل ال navbar الخاص بك 

<NavLink exact={true} activeClassName='is-active' to='/'>Home</NavLink>
<NavLink activeClassName='is-active' to='/about'>About</NavLink>
<NavLink activeClassName='is-active' to='/users'>Users</NavLink>

عند بدء التطبيق سوف يكون اللينك الخاص ب Home هو النشط وسوف يأخذ التنسيق الخاص بالكلاس "is-active"

وعند التنقل بين الروابط سوف يطبق التنسيق على الرابط النشط.

رابط هذا التعليق
شارك على الشبكات الإجتماعية

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...