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 实现路由重定向



相关推荐
10年前端老司机12 分钟前
React 受控组件和非受控组件区别和使用场景
前端·javascript·react.js
夏晚星13 分钟前
vue实现微信聊天emoji表情
前端·javascript
停止重构15 分钟前
【方案】前端UI布局的绝技,响应式布局,多端适配
前端·网页布局·响应式布局·grid布局·网页适配多端
極光未晚15 分钟前
TypeScript在前端项目中的那些事儿:不止于类型的守护者
前端·javascript·typescript
ze_juejin16 分钟前
Vue3 + Vite + Ant Design Vue + Axios + Pinia 脚手架搭建
前端·vue.js
Rrvive17 分钟前
原型与原型链到底是什么?
javascript
lichenyang45318 分钟前
React项目(移动app)
前端
用户618482402195119 分钟前
Vue-library-start,一个基于Vite的vue组件库开发模板
前端
美团技术团队31 分钟前
报名 | 美团技术沙龙第86期:多业务场景下,美团如何做性能优化
前端
安替-AnTi1 小时前
基于 React 和 TypeScript 搭建的机器学米其林餐厅数据分析项目
react.js·typescript·数据分析·毕设·米其林