React路由搭建

目录

一、安装react-router-dom

 二、创建路由文件和页面文件

三、写入对应文件代码

 四、修改入口index.js

五、修改App.js,插入路由

六、实现效果


一、安装react-router-dom
npm install react-router-dom

安装完成后在package.json文件中进行查看:

 二、创建路由文件和页面文件

三、写入对应文件代码
// router.js
import Home from "../pages/home/index";
import Login from "../pages/login/index";
import NotFound from "../pages/notFound/index";
 
const routers = [
    {
        path: '/Home',
        name: '主页面',
        components: Home
    },
    {
        path: '/Login',
        name: '登录页',
        components: Login
    },
    {
        path: '/NotFound',
        name: '404',
        components: NotFound
    }
]
 
export default routers;
// home.js
import React from 'react';
import './index.css';
 
function Home() {
    return (
        <div className='Home Home-pagination'>主页面</div>
    )
}
export default Home;

// login.js
import React from 'react';
import './index.css';
 
function Login() {
    return (
        <div className='Home Home-pagination'>登录页面</div>
    )
}
export default Login;

// 404
import React from 'react';
import './index.css';
 
function NotFound() {
    return (
        <div className='Home Home-pagination'>404</div>
    )
}
export default NotFound;
 四、修改入口index.js
// 引入react-router-dom的BrwoserRouter用来包住App整个页面
import React from 'react';
import ReactDOM from 'react-dom/client';
import './index.css';
import App from './App';
import reportWebVitals from './reportWebVitals';
import { BrowserRouter } from 'react-router-dom';
 
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(
  <React.StrictMode>
    <BrowserRouter>
      <App />
    </BrowserRouter>
  </React.StrictMode>
);
 
reportWebVitals();
五、修改App.js,插入路由
import './App.css';
import routers from './router';
import { Routes, Link, Route } from 'react-router-dom';
 
function App() {
  return (
    <div className="App App-header">
      <div className="App App-router">
        {
        routers.map((item, index) => (
          <Link className="App App-link" to={item.path} key={index}> {item.name} </Link>
        ))
        }
      </div>
      <Routes className="App App-content">
        {
          routers.map((item, index) => (
            <Route path={item.path} key={index} element={<item.components />}></Route>
          ))
        }
      </Routes>
    </div >
  );
}
 
export default App;
六、实现效果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值