当前位置: 首页 > wzjs >正文

南京做网站外包免费行情软件网站下载大全

南京做网站外包,免费行情软件网站下载大全,最近流感疫情2020,专门做任务的网站文章目录 前言✅ React Router vs Vue Router 对比一览🧩 React Router 的底层原理简述① 路由声明与匹配(基于 JSX)② 历史模式管理③ 响应式状态处理④ 路由渲染机制(Outlet) ✅ 总结:原理是否一样&#…

文章目录

  • 前言
    • ✅ React Router vs Vue Router 对比一览
    • 🧩 React Router 的底层原理简述
      • ① 路由声明与匹配(基于 JSX)
      • ② 历史模式管理
      • ③ 响应式状态处理
      • ④ 路由渲染机制(Outlet)
    • ✅ 总结:原理是否一样?
  • 完整示例
    • ✅ 示例目标:
    • 📦 1. 安装依赖
    • 🧩 2. 目录结构
    • 🧱 3. 实现组件
      • `App.tsx`
      • `ProtectedRoute.tsx`
      • `DashboardLayout.tsx`
      • `Profile.tsx` / `Settings.tsx`
      • `Login.tsx`
      • `Home.tsx`
    • ✅ 效果总结
      • 后续:


前言

React 社区主流使用的是 React Router,它和 Vue Router 是功能上非常类似的客户端路由库,但底层实现原理与 Vue Router 在设计理念上有显著差异


✅ React Router vs Vue Router 对比一览

特性 / 对比项Vue RouterReact Router
配置方式配置式:通过 routes 数组注册声明式:通过 JSX 结构描述嵌套关系
路由定义createRouter({ routes })<Route path="/" element={<Home />}>
路由嵌套嵌套路由由 children 配置JSX 中嵌套 <Route> 实现嵌套路由
响应式机制依赖Vue 响应式系统React 状态系统(useState, useEffect
导航守卫beforeEach, beforeRouteEnter没有内建守卫,需自定义封装逻辑组件
底层历史机制自己封装了一套 History 模块直接使用 historyreact-router-dom 的 history 包
路由渲染组件<router-view><Outlet>

🧩 React Router 的底层原理简述

React Router 的核心机制分为:

① 路由声明与匹配(基于 JSX)

  • React Router 利用 JSX 定义 Route 树,使用的是声明式 API:
<Routes><Route path="/" element={<Home />} /><Route path="/about" element={<About />} />
</Routes>
  • Routes 组件内部会解析子 Route 节点,构建匹配树并与 window.location.pathname 匹配。

② 历史模式管理

  • react-router-dom 提供的 BrowserRouter / HashRouter
<BrowserRouter>  // HTML5 History API
<HashRouter>     // Hash 模式
  • 内部使用了 history 包(https://github.com/remix-run/history)来封装 URL 操作。

③ 响应式状态处理

React Router 使用自己的 useLocation()useNavigate()useParams() 来读取当前状态或跳转。

内部用 React Context + useReducer 实现状态追踪和通知刷新。


④ 路由渲染机制(Outlet)

React Router 使用 <Outlet /> 实现嵌套路由组件插槽渲染,类似 Vue 的 <router-view>

<Route path="settings" element={<SettingsLayout />}><Route path="profile" element={<Profile />} />
</Route>

SettingsLayout 组件中使用 <Outlet /> 来渲染 Profile


✅ 总结:原理是否一样?

相同点不同点
都使用 history API 或 hash 进行地址管理Vue 用配置式路由表;React 用 JSX 声明式结构
都支持嵌套路由、动态参数、懒加载、路由组件渲染等Vue 内建导航守卫;React 需自行通过组件逻辑封装
都有 <router-view> / <Outlet> 类似插槽来决定显示哪个组件React 更强调函数式组件和 hooks,Vue 更强调响应式系统和生命周期钩子

完整示例

下面给出一个 React Router v6+ 实现导航守卫和嵌套路由的完整示例,可以类比 Vue Router 的 beforeEachmeta.requiresAuth 功能。


✅ 示例目标:

  • 实现一个登录保护机制:/dashboard 只能登录后访问。
  • 使用嵌套路由:/dashboard/profile/dashboard/settings
  • 使用 <Outlet /> 类似 Vue 的 <router-view>

📦 1. 安装依赖

npm install react-router-dom

🧩 2. 目录结构

src/
├─ App.tsx
├─ routes/
│  ├─ ProtectedRoute.tsx
│  ├─ DashboardLayout.tsx
│  ├─ Profile.tsx
│  ├─ Settings.tsx
├─ pages/
│  ├─ Login.tsx
│  ├─ Home.tsx

🧱 3. 实现组件

App.tsx

import { BrowserRouter, Routes, Route } from 'react-router-dom'
import Home from './pages/Home'
import Login from './pages/Login'
import DashboardLayout from './routes/DashboardLayout'
import ProtectedRoute from './routes/ProtectedRoute'
import Profile from './routes/Profile'
import Settings from './routes/Settings'export default function App() {return (<BrowserRouter><Routes><Route path="/" element={<Home />} /><Route path="/login" element={<Login />} />{/* 嵌套路由 + 路由守卫 */}<Route element={<ProtectedRoute />}><Route path="/dashboard" element={<DashboardLayout />}><Route path="profile" element={<Profile />} /><Route path="settings" element={<Settings />} /></Route></Route></Routes></BrowserRouter>)
}

ProtectedRoute.tsx

import { Navigate, Outlet } from 'react-router-dom'// 假设是全局变量 / 状态管理
const isAuthenticated = () => !!localStorage.getItem('token')export default function ProtectedRoute() {return isAuthenticated() ? <Outlet /> : <Navigate to="/login" />
}

📌 类似于 Vue 的导航守卫 beforeEnter


DashboardLayout.tsx

import { Outlet, Link } from 'react-router-dom'export default function DashboardLayout() {return (<div><h2>Dashboard</h2><nav><Link to="profile">Profile</Link> | <Link to="settings">Settings</Link></nav><hr /><Outlet /> {/* 嵌套路由入口 */}</div>)
}

Profile.tsx / Settings.tsx

export default function Profile() {return <div>👤 This is your profile.</div>
}export default function Settings() {return <div>⚙️ Here are your settings.</div>
}

Login.tsx

import { useNavigate } from 'react-router-dom'export default function Login() {const navigate = useNavigate()const login = () => {localStorage.setItem('token', 'dummy')navigate('/dashboard')}return <button onClick={login}>Login</button>
}

Home.tsx

import { Link } from 'react-router-dom'export default function Home() {return (<div><h1>🏠 Home Page</h1><Link to="/dashboard">Go to Dashboard</Link></div>)
}

✅ 效果总结

  • 未登录访问 /dashboard/profile 会跳转 /login
  • 登录后会自动导航回 dashboard。
  • 嵌套路由使用 <Outlet /> 插槽进行渲染,结构清晰。

后续:

  1. React Router + Zustand 权限管理系统(支持登录、角色验证、自动跳转)
  2. token 校验 + 自动续签 + 刷新记住身份 的版本
http://www.dtcms.com/wzjs/526854.html

相关文章:

  • 怎样进入医院公众号seo软件推荐
  • 东宁网站制作童程童美少儿编程怎样收费
  • 一流学科建设专题网站网络舆情监测与研判
  • 深圳网站建设 迈网站注册地址
  • wordpress 获得主题seo优化轻松seo优化排名
  • 怎么查看网站有没有做301成都seo优化排名推广
  • 长沙做营销型网站公司郑州seo方案
  • 中国兰州网招聘电商网站seo怎么做
  • 辽宁沈阳做网站百度搜索引擎广告位的投放
  • flash 网站视频曲靖seo建站
  • 广告公司图片大全保定seo网络推广
  • wordpress后台修改搜狗排名优化工具
  • 在家做私房菜的网站网站推广网
  • 网站建设中 模版中国十大经典广告
  • dede 网站版权信息西安专业seo
  • 聚诚商务做网站多少钱合肥seo管理
  • 熵网站seo入门培训班
  • editplus怎么创网站苏州百度快照优化排名
  • 有个音乐网站老板做淫秽直播被抓阿里巴巴官网首页
  • 网络文化经营许可证变更安徽网站seo
  • 做商城网站需要的功能seo报价单
  • 建湖专业做网站的公司深圳营销型网站建设
  • 高端h5网站开发做seo用哪种建站程序最好
  • 怎么给网站做链接屏蔽百度软文推广怎么做
  • php 企业网站模板网站优化推广seo
  • 关于网站建设live2500宁波seo如何做推广平台
  • 智慧团建网登录入口seo快速优化方法
  • 做实体童装店在哪个网站批发好全网推广的方式
  • 怎么注册一个属于自己的网站太原做网站推广的公司
  • div css旅游网站模板网络推广员招聘