路由组件与一般组件的区别

路由组件与一般组件的区别

1. 基本概念

1.1 路由组件

路由组件是指通过路由规则映射的组件,通常放在 pagesviews 文件夹中。

1.2 一般组件

一般组件是指通过 import 导入后直接使用的组件,通常放在 components 文件夹中。

2. 主要区别

2.1 存放位置

src/
├── pages/          # 路由组件
│   ├── Home/
│   ├── About/
│   └── User/
├── components/     # 一般组件
│   ├── Header/
│   ├── Footer/
│   └── Sidebar/

2.2 接收参数方式

  1. 路由组件
// 路由组件可以接收路由参数
const UserDetail = () => {// 通过路由获取参数const { id } = useParams();  // React Router// 或const route = useRoute();    // Vue Routerconst id = route.params.id;return <div>User ID: {id}</div>;
};// 路由配置
const routes = [{path: '/user/:id',component: UserDetail}
];
  1. 一般组件
// 一般组件通过 props 接收参数
const Button = ({ text, onClick }) => {return <button onClick={onClick}>{text}</button>;
};// 使用组件
const App = () => {return <Button text="Click me" onClick={() => console.log('clicked')} />;
};

2.3 生命周期管理

  1. 路由组件
// React 路由组件
const HomePage = () => {useEffect(() => {// 组件挂载时触发console.log('Route component mounted');return () => {// 路由切换时触发卸载console.log('Route component will unmount');};}, []);return <div>Home Page</div>;
};// Vue 路由组件
export default {name: 'HomePage',beforeRouteEnter(to, from, next) {// 路由进入前next();},beforeRouteLeave(to, from, next) {// 路由离开前next();}
};
  1. 一般组件
// React 一般组件
const Header = () => {useEffect(() => {// 组件挂载时触发console.log('Normal component mounted');return () => {// 父组件更新或条件渲染时可能触发卸载console.log('Normal component will unmount');};}, []);return <header>Header</header>;
};// Vue 一般组件
export default {name: 'Header',mounted() {console.log('Normal component mounted');},beforeDestroy() {console.log('Normal component will be destroyed');}
};

2.4 组件复用性

  1. 路由组件
  • 通常是页面级组件
  • 复用性较低
  • 包含业务逻辑
  • 可能包含多个一般组件
  1. 一般组件
  • 通常是功能级组件
  • 复用性高
  • 专注于特定功能
  • 可被多个路由组件使用

3. 实际应用示例

3.1 路由组件示例

// src/pages/UserList/index.jsx
import { useEffect, useState } from 'react';
import { Table, Button } from '../../components';const UserList = () => {const [users, setUsers] = useState([]);useEffect(() => {// 获取用户列表数据fetchUsers();}, []);return (<div className="user-list-page"><h1>User List</h1><Table data={users} /><Button text="Refresh" onClick={fetchUsers} /></div>);
};export default UserList;

3.2 一般组件示例

// src/components/Table/index.jsx
const Table = ({ data, columns, onRowClick }) => {return (<table className="common-table"><thead><tr>{columns.map(column => (<th key={column.key}>{column.title}</th>))}</tr></thead><tbody>{data.map(row => (<tr key={row.id} onClick={() => onRowClick(row)}>{columns.map(column => (<td key={column.key}>{row[column.key]}</td>))}</tr>))}</tbody></table>);
};export default Table;

4. 开发建议

4.1 路由组件开发建议

  1. 职责划分

    • 负责页面级的状态管理
    • 处理路由相关的逻辑
    • 组织和协调一般组件
  2. 代码组织

// 推荐的路由组件结构
src/pages/UserManagement/
├── index.jsx          // 主组件
├── service.js         // API 请求
├── model.js           // 数据模型
├── constants.js       // 常量定义
└── style.less         // 样式文件

4.2 一般组件开发建议

  1. 设计原则

    • 保持组件的独立性
    • 提供良好的 Props 接口
    • 避免耦合业务逻辑
  2. 代码组织

// 推荐的一般组件结构
src/components/DataTable/
├── index.jsx          // 主组件
├── components/        // 子组件
├── hooks/            // 自定义 hooks
├── utils.js          // 工具函数
└── style.less        // 样式文件

5. 性能优化

5.1 路由组件优化

// 路由懒加载
const UserList = React.lazy(() => import('./pages/UserList'));// 路由配置
const routes = [{path: '/users',component: () => (<Suspense fallback={<Loading />}><UserList /></Suspense>)}
];

5.2 一般组件优化

// 使用 memo 优化渲染
const Table = React.memo(({ data, columns }) => {return (// 表格渲染逻辑);
});// 使用 useMemo 优化计算
const List = ({ items }) => {const sortedItems = useMemo(() => {return [...items].sort((a, b) => a.id - b.id);}, [items]);return (// 列表渲染逻辑);
};

6. 总结

6.1 关键区别

  1. 定位不同

    • 路由组件:页面级,负责整体布局和业务逻辑
    • 一般组件:功能级,负责特定功能的实现
  2. 参数传递

    • 路由组件:主要通过路由参数
    • 一般组件:主要通过 props
  3. 生命周期

    • 路由组件:与路由切换紧密相关
    • 一般组件:与父组件更新相关

6.2 使用建议

  1. 合理划分组件类型
  2. 遵循单一职责原则
  3. 注重组件的可复用性
  4. 保持良好的代码组织结构
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/503331.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Qt天气预报系统设计界面布局第四部分右边

Qt天气预报系统 1、第四部分右边的第一部分1.1添加控件 2、第四部分右边的第二部分2.1添加控件 3、第四部分右边的第三部分3.1添加控件3.2修改控件名字 1、第四部分右边的第一部分 1.1添加控件 拖入一个widget&#xff0c;改名为widget04r作为第四部分的右边 往widget04r再拖…

数据库系统概论期末复习

期末考试题型&#xff1a; 选择题 20题 20分 判断题 10题 10分 简答题 4题 20分 SQL语句&#xff1a; &#xff08;select delete update&#xff09;30分 设计题&#xff1a;ER图 和关系模式 ER转关系模式&#xff0c;注意主码&#xff0c;外码的标注 15分 应用题&#xff1a;…

uni-app 页面生命周期及组件生命周期汇总(Vue2、Vue3)

文章目录 一、前言&#x1f343;二、页面生命周期三、Vue2 页面及组件生命周期流程图四、Vue3 页面及组件生命周期流程图4.1 页面加载时序介绍4.2 页面加载常见问题4.3 onShow 和 onHide4.4 onInit4.5 onLoad4.6 onReachBottom4.7 onPageScroll4.8 onBackPress4.9 onTabItemTap…

微信小程序中 “页面” 和 “非页面” 的区别

微信小程序中 “页面” 和 “非页面” 的区别&#xff0c;并用表格进行对比。 核心概念&#xff1a; 页面 (Page)&#xff1a; 页面是微信小程序中用户可以直接交互的视图层&#xff0c;也是小程序的基本组成部分。每个页面都有自己的 WXML 结构、WXSS 样式和 JavaScript 逻辑…

【Linux】传输层协议UDP

目录 再谈端口号 端口号范围划分 UDP协议 UDP协议端格式 UDP的特点 UDP的缓冲区 UDP注意事项 进一步深刻理解 再谈端口号 在上图中&#xff0c;有两个客户端A和B&#xff0c;客户端A打开了两个浏览器&#xff0c;这两个客户端都访问同一个服务器&#xff0c;都访问服务…

大数据架构演变

一、离线数仓 缺点&#xff1a; ETL计算、存储、时间成本高数据处理链路过长无法支持实时、近实时的数据分析数据采集对业务库造成影响 二、Lambda架构&#xff0c;离线实时分开 缺点&#xff1a; 组件多&#xff0c;不方便管理很难保证数据一致数据探查困难&#xff0c;出现…

进程间通讯

简介&#xff1a; 进程间通讯方式有&#xff1a; 1.内存映射&#xff08;mmap&#xff09;&#xff1a; 使用mmap函数将磁盘空间映射到内存 2.管道 3.信号 4.套接字&#xff08;socket&#xff09; 5.信号机制 通过进程中kill函数&#xff0c;去给另一个函数发送信号&a…

毕业项目推荐:基于yolov8/yolov5的行人检测识别系统(python+卷积神经网络)

文章目录 概要一、整体资源介绍技术要点功能展示&#xff1a;功能1 支持单张图片识别功能2 支持遍历文件夹识别功能3 支持识别视频文件功能4 支持摄像头识别功能5 支持结果文件导出&#xff08;xls格式&#xff09;功能6 支持切换检测到的目标查看 二、数据集三、算法介绍1. YO…

[桌面运维]windows自动设置浅深色主题

设置自动浅色/深色主题 我看很多up主的教程过于繁琐&#xff0c;需要添加四个功能&#xff0c;并且有些还不能生效&#xff01; 大多数都是教程&#xff1a; 自动任务栏浅色 add HKCUSOFTWAREMicrosoftWindowsCurrentVersionThemesPersonalize/v SystemUsesLightTheme /t …

LQ quarter 5th

目录 B. 开赛主题曲 C. BlueAI E. 精准难度 B. 开赛主题曲 &#xff08;1&#xff09;两层循环枚举所有子串。第一层子串长度&#xff0c;第二层子串起点 &#xff08;2&#xff09;判子串是否合法还要一个 for&#xff0c;26 * 26 * 2e5 快要超时&#xff0c;因此计算每个字母…

Directx12 chapter4

官方的初始化需要的组件 Initialize 初始化涉及到首次设置全局变量和类&#xff0c;initialize 函数必须准备管道和资产。 初始化管道。 启用调试层。创建设备。创建命令队列。创建交换链。创建渲染器目标视图 (RTV) 描述符堆。 备注 可将描述符堆视为描述符的数组。 其中…

STM32 软件I2C读写

单片机学习&#xff01; 目录 前言 一、软件I2C读写代码框架 二、I2C初始化 三、六个时序基本单元 3.1 引脚操作的封装和改名 3.2 起始条件执行逻辑 3.3 终止条件执行逻辑 3.4 发送一个字节 3.5 接收一个字节 3.5 发送应答&接收应答 3.5.1 发送应答 3.5.2 接…

计算机网络--UDP和TCP课后习题

【5-05】 试举例说明有些应用程序愿意采用不可靠的UDP, 而不愿意采用可靠的TCP。 解答&#xff1a; 这可能有以下几种情况。 首先&#xff0c;在互联网上传输实时数据的分组时&#xff0c;有可能会出现差错甚至丢失。如果利用 TCP 协议对这些出错或丢失的分组进行重传&…

【C++】B2099 矩阵交换行

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;题目描述题目描述输入格式输出格式输入输出样例输入 #1输出 #1 &#x1f4af;题目分析&#x1f4af;不同解法分析我的做法实现步骤&#xff1a;优点&#xff1a;不足&#…

[微服务]redis主从集群搭建与优化

搭建主从集群 单节点Redis的并发能力是有上限的&#xff0c;要进一步提高Redis的并发能力&#xff0c;就需要搭建主从集群&#xff0c;实现读写分离。 1. 主从集群结构 下图就是一个简单的Redis主从集群结构&#xff1a; 如图所示&#xff0c;集群中有一个master节点、两个s…

使用WebSocket 获取实时数据

回车发送数据&#xff0c;模拟服务器发送数据 效果图&#xff1a; 源码&#xff1a; <template><div><h1>WebSocket 实时数据</h1><input type"text" v-model"ipt" keyup.enter"sendMessage(ipt)"><div v-if…

Element-UI:如何实现表格组件el-table多选场景下根据数据对某一行进行禁止被选中?

如何实现表格组件el-table多选场景下根据数据对某一行进行禁止被选中&#xff1f; 在使用 Element UI 的 Table 组件时&#xff0c;如果你想要禁用某一行的选中&#xff08;特别是在多选模式下&#xff09;&#xff0c;可以通过自定义行的 selectable 属性来实现。selectable …

移动端自动化测试Appium-java

一、Appium的简介 移动端的自动化测试框架 模拟人的操作进行功能自动化常用于功能测试、兼容性测试 跨平台的自动化测试 二、Appium的原理 核心是web服务器&#xff0c;接受客户端的连接&#xff0c;接收客户端的命令&#xff0c;在手机设备上执行命令&#xff0c;收集命令…

Geoserver修行记-后端调用WMS/WMTS服务无找不到图层Could not find layer

项目场景 调用geoserver地图服务WMS,找不到图层 我在进行地图服务调用的时候&#xff0c;总是提示我找不多图层 Could not find layer&#xff0c;重点是这个图层我明明是定义了&#xff0c;发布了&#xff0c;且还能够正常查看图层的wms的样式&#xff0c;但是在调用后端调用…

深入探讨 Android 中的 AlarmManager:定时任务调度及优化实践

引言 在 Android 开发中&#xff0c;AlarmManager 是一个非常重要的系统服务&#xff0c;用于设置定时任务或者周期性任务。无论是设置一个闹钟&#xff0c;还是定时进行数据同步&#xff0c;AlarmManager 都是不可或缺的工具之一。然而&#xff0c;随着 Android 系统的不断演…