为了账号安全,请及时绑定邮箱和手机立即绑定

【学习打卡】第8天 实战旅游项目

标签:
Html5

学习打卡】第8天 实战旅游项目

课程名称:[React 17/18 系统精讲 结合TS打造旅游电商平台]

课程章节: 主页开发及路由

主讲老师:阿莱克斯

课程内容:

  1. 配置react-router
  2. 基础路由及页面导航
  3. useNavigate()钩子与Link组件-

课程收获:

routet-router 封装原生JS的路由库
主要分别为
  • react-router-dom 用于浏览器,处理web app的路由

    • 实现H5API切换
    • 利用HASH进行路由切换
  • react-router-native 用于React Native 处理手机APP的路由

  • react-router-redux 路由中间件,处理redux集成

  • react-router-config 配置静态路由

建立 login register detail 文件夹 在detail文件中获取路由参数
import React from "react";
import { useParams } from "react-router-dom";
import styles from "./Register.module.scss";
export const Detail: React.FC = () => {
  // 使用该钩子函数获取路由传递过来的参数
  const params = useParams();
  return (
    <>
      <h1>ID: {params.ID}</h1>
    </>
  );
};
利用TS对传入的参数加上类型 并进行智能提示
// 为传递的参数加上类型
type MatchParams = {
  ID?: string;
};
export const Detail: React.FC = () => {
  // 使用该钩子函数获取路由传递过来的参数
  const params = useParams<MatchParams>();
为未找到的路由配置404页面
          {/*配置404页面*/}
          <Route
            element={
              <h1 style={{ textAlign: "center", fontSize: 30 }}>
                404 页面不存在
              </h1>
            }
            path="*"
          ></Route>
react-router 如何传递路由信息
  1. v5:props 注入获取路由状态

    • class: withRouter
    • fc: useLocation useHistory

    v6: 大改革 全面倒向 fc: useLocation useNavigate

    • const navigate = useNavigate()
      	      <Button onClick={()=>navigate('/register')}>注册</Button>
                <Button onClick={()=>navigate('/login')}>登陆</Button>
      const location = useLocation()
      const params = useParams()
      
  2. 使用Link组件跳转带参 优化体验

     <Link to={`detail/${id}`}>
    

    图片描述

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消