原来这就是react设计模式啊

最近React项目开发中, 想把数据、逻辑、视图分离,以提升项目的可维护性、可扩展性和可测性,记录下我用的分离方式

先看个代码示例吧:

数据请求(useData.js)逻辑封装也可以用useHook

如果业务开发中有许多兄弟或者子(孙)组件,可以利用useContext/Provider,这样每个组件都可以用useContext拿到useData.js的数据

js 复制代码
// hooks/useData.js 
import { useState, useEffect } from 'react'; 

export function useData(userId) { 
    const [data, setData] = useState(null); 
    const [loading, setLoading] = useState(true); 
    
    useEffect(() => { 
        fetch(`/api/user/${userId}`) 
          .then(res => res.json()) 
          .then(json => setData(json)) 
          .finally(() => setLoading(false)); 
    }, [userId]); 
    
    return { data, loading }; 
}
视图组件(Box.js)
js 复制代码
// components/Box.js
export function Box({ user, loading }) {
  if (loading) return <div>加载中...</div>;
  if (!user) return <div>未找到用户</div>;
  return (
    <div>
      <h2>{user.name}</h2>
      <p>邮箱:{user.email}</p>
    </div>
  );
}
容器组件(UserContainer.js)
js 复制代码
// containers/UserContainer.js
import { useUserData } from '../hooks/useUserData';
import { UserView } from '../components/UserView';

export function UserContainer({ userId }) {
  const { data, loading } = useUserData(userId);
  return <UserView user={data} loading={loading} />;
}

总结:

  • 数据:用 hooks/service 统一管理和请求。
  • 逻辑:可以用 hooks/service 封装,容器组件只调用 或者 直接写在容器组件。
  • 视图:纯展示组件,无业务逻辑和数据请求。

这样,可以有效实现"数据、逻辑、视图"三者的分离,使代码更清晰易维护

解释

数据层(Data)
  • 状态管理 :使用 React 的 useStateuseReducer,或外部库(如 Redux、MobX、Recoil、Zustand 等)管理数据。
  • 数据请求 :将 API 请求封装在单独的模块或 hooks(如 useFetchUser),避免在组件内直接请求和处理数据。
  • 数据抽象 :通过自定义 hooks(如 useUserData)将数据获取和处理逻辑与 UI 解耦。
逻辑层(Logic)
  • 自定义 Hooks :把业务逻辑、状态操作封装到 hooks(如 useLoginuseForm),组件只关心如何展示。
  • 服务层:将复杂业务逻辑(如表单验证、流程控制)独立成 service 文件或 hooks。
  • 事件处理:事件处理函数尽量独立,不直接写在 JSX 内联。
视图层(View)
  • 纯展示组件:只负责渲染 UI,根据 props 显示内容,无内部状态和副作用。

  • 容器组件:负责连接数据和逻辑,将数据和事件通过 props 传递给展示组件。

相关推荐
香蕉可乐荷包蛋3 小时前
浅入ES5、ES6(ES2015)、ES2023(ES14)版本对比,及使用建议---ES6就够用(个人觉得)
前端·javascript·es6
未来之窗软件服务3 小时前
资源管理器必要性———仙盟创梦IDE
前端·javascript·ide·仙盟创梦ide
liuyang___4 小时前
第一次经历项目上线
前端·typescript
西哥写代码5 小时前
基于cornerstone3D的dicom影像浏览器 第十八章 自定义序列自动播放条
前端·javascript·vue
清风细雨_林木木5 小时前
Vue 中生成源码映射文件,配置 map
前端·javascript·vue.js
FungLeo5 小时前
node 后端和浏览器前端,有关 RSA 非对称加密的完整实践, 前后端匹配的代码演示
前端·非对称加密·rsa 加密·node 后端
雪芽蓝域zzs5 小时前
JavaScript splice() 方法
开发语言·javascript·ecmascript
不灭锦鲤5 小时前
xss-labs靶场第11-14关基础详解
前端·xss
不是吧这都有重名6 小时前
利用systemd启动部署在服务器上的web应用
运维·服务器·前端
霸王蟹6 小时前
React中巧妙使用异步组件Suspense优化页面性能。
前端·笔记·学习·react.js·前端框架