React 开发一个移动端项目(2)

配置基础路由

目标:配置登录页面的路由并显示在页面中

步骤

  1. 安装路由:

yarn add react-router-dom@5.3.0

@5 和 @6 两个版本对组件类型的兼容性和函数组件支持有所改变,在这里使用的是 @5。

和路由的类型声明文件

yarn add @types/react-router-dom -D

使用 -D 标志将其添加为开发依赖项,这意味着它只会在开发过程中使用,而不会包含在最终的生产构建中。

  1. 在 pages 目录中创建两个文件夹:Login、Layout
  1. 分别在两个目录中创建 index.tsx 文件,并创建一个简单的组件后导出

src\pages\Layout\index.tsx

js 复制代码
export default function Layout() {
  return <div>布局页面</div>;
}

src\pages\Login\index.tsx

js 复制代码
const Login = () => {
  return <div>登录页面</div>;
};
export default Login;
  1. 在 App 组件中,导入路由组件以及两个页面组件,并配置 Login 和 Layout 的路由规则
js 复制代码
import "./App.scss";
// 导入路由
// as 是ES6中的特性,允许为导入的模块或对象指定新的名称。
import { BrowserRouter as Router, Route } from "react-router-dom";

// 导入页面组件
import Layout from "./pages/Layout";
import Login from "./pages/Login";

// 配置路由规则
function App() {
  return (
    <Route>
      <div className="app">
        <Route path="/home">
          <Layout></Layout>
        </Route>
        <Route path="/login">
          <Login></Login>
        </Route>
      </div>
    </Route>
  );
}

export default App;

默认展示首页内容

目标:能够在打开页面时就展示首页内容

分析说明

匹配默认路由,进行重定向

步骤

  1. 在 App.tsx 中添加一个新的 Route,用来匹配默认路由

在这里修改了路由的导入

import { Router, Route, Switch, Redirect } from "react-router-dom";

  1. 为 Route 组件添加 render 属性,用来渲染自定义内容

  2. 在 render 中,渲染 Redirect 实现路由重定向



相关推荐
沐爸muba13 分钟前
JS中的for...in和for...of有什么区别?
前端·javascript
lljss202013 分钟前
表格HTML
前端·html
桃花加酥17 分钟前
js笔记(二进制由0和1两个数字组成)
java·javascript
慕仲卿1 小时前
为什么要使用补码表示负数
javascript
集成显卡1 小时前
快来用 Rspack/Rsbuild + pnpm 构建你的 monorepo 全栈项目
javascript·webpack·rust
xmh-sxh-13141 小时前
前端常用的主流框架有哪些
前端
程序员大金1 小时前
基于SpringBoot+Vue+MySQL的校园一卡通系统
java·javascript·vue.js·spring boot·后端·mysql·tomcat
m0_528723811 小时前
vue2与vue3的区别
前端·javascript·vue.js
J不A秃V头A2 小时前
el-table使用el-switch选择器没效果
javascript·vue.js·elementui
huangfuyk2 小时前
Vue3+Element Plus:使用el-dialog,对话框可拖动,且对话框弹出时仍然能够在背景页(对话框外部的页面部分)上进行滚动以及输入框输入信息
前端·javascript·vue.js·vue 3