Link 标签在 ReactJs 中不起作用,白屏

Link tag not working in ReactJs, white screen

我正在 React Js 应用程序中使用 bootstrap 导航栏。当我使用以下代码时,屏幕甚至连导航栏都不显示任何内容,但是当我用 'a' 标记替换 'Link' 标记并且 to='' 到 href='' 它有效时,为什么会这样?编译也没有错误

import React from 'react';
import {Link} from "react-router-dom";
export default function Navbar() {
  return (
    <>
    <nav className="navbar navbar-expand-lg navbar-dark bg-dark">
  <div className="container-fluid">
    <Link className="navbar-brand" to="/">Navbar</Link>
    <button className="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
      <span className="navbar-toggler-icon"></span>
    </button>
    <div className="collapse navbar-collapse" id="navbarSupportedContent">
      <ul className="navbar-nav ms-auto mb-2 mb-lg-0">

        <li className="nav-item pe-3" style={{display:'flex',alignItems:'center'}}>
        <svg xmlns="http://www.w3.org/2000/svg" x="0px" y="0px"
        width="24" height="24" fill='white'
        viewBox="0 0 64 64"
        ><path d="M 32 3 L 1 28 L 1.4921875 28.654297 C 2.8591875 30.477297 5.4694688 30.791703 7.2304688 29.345703 L 32 9 L 56.769531 29.345703 C 58.530531 30.791703 61.140812 30.477297 62.507812 28.654297 L 63 28 L 54 20.742188 L 54 8 L 45 8 L 45 13.484375 L 32 3 z M 32 13 L 8 32 L 8 56 L 56 56 L 56 35 L 32 13 z M 26 34 L 38 34 L 38 52 L 26 52 L 26 34 z"></path></svg>
          <Link className="nav-link active"  aria-current="page" to="/">
          Home</Link>
        </li>

        <li className="nav-item pe-3"  style={{display:'flex',alignItems:'center'}} >
        <svg xmlns="http://www.w3.org/2000/svg" x="0px" y="0px"
        width="24" height="24"
        viewBox="0 0 48 48"
><path fill="#2196F3" d="M37,40H11l-6,6V12c0-3.3,2.7-6,6-6h26c3.3,0,6,2.7,6,6v22C43,37.3,40.3,40,37,40z"></path><path fill="#FFF" d="M22 20H26V31H22zM24 13A2 2 0 1 0 24 17 2 2 0 1 0 24 13z"></path></svg>
          <Link className="nav-link active mr-5" to="/">About</Link>
        </li>

        <li className="nav-item pe-3" style={{display:'flex',alignItems:'center'}} >

        <img style={{height:'24px',width:'24px'}} alt='' src="https://img.icons8.com/external-bearicons-outline-color-bearicons/64/000000/external-sign-up-call-to-action-bearicons-outline-color-bearicons-1.png"/>
          <Link className="nav-link active" to="/signup">Sign Up </Link>
        </li>


        <li className="nav-item pe-3" style={{display:'flex',alignItems:'center'}}>
        <img  style={{height:'28px',width:'28px'}} src="" alt=''/>
          <Link className="nav-link active" to="/login">Login</Link>
        </li>
       
      </ul>
      
    </div>
  </div>
</nav>


    </>
  )
}

路线

import Navbar from './components/Navbar';
import Homegif from './components/Homegif';
import {
  BrowserRouter as Router,

  Route,Routes
} from "react-router-dom";
import Signup from './components/Signup';
import Login from './components/Login';

function App() {
  return (
    <>
    <Navbar/>
    <Router>
    
    <Routes>
          <Route exact path="/" element={<Homegif/>}>
              
          </Route>
          <Route exact path="/signup" element={<Signup/>}>
          
          </Route>
          <Route exact path="/login" element={<Login/>}>
            
          </Route>
      </Routes>




  
    </Router>
    
    </>
   
  );
}

export default App;

这是包含路由的文件。这是在我出错的另一个页面上呈现的。

您正在将 <Link className="nav-link active" to="/login">Login</Link> 与 class 一起使用,这就是为什么如果您想将 Link 标签与 class react-router-dom 向 NavLink 提供 class 属性,尝试将其更改为:


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

<NavLink className="nav-link active" to="/login">Login</Link>

使用 NavLink 而不是 Link 来使用 class 属性。

你应该这样定义你的路线

import Navbar from './components/Navbar';
import Homegif from './components/Homegif';
import {BrowserRouter as Router,Route,Routes} from "react-router-dom";
import Signup from './components/Signup';
import Login from './components/Login';

function App() {
  return (
    <>
    <Router>
          <Navbar/>
          <Routes>
          <Route exact path="/" element={<Homegif/>}/>
          <Route exact path="/signup" element={<Signup/>}/>
          <Route exact path="/login" element={<Login/>}/>
          <Routes/>
    </Router>
    </>
  );
}

export default App;

希望这会解决您的问题