
页面
包含由应用程序路由定义的顶级组件。 它们从模块文件夹中导入更多低级组件(详细信息见下文)。模块
每个模块代表一个功能或一组功能,包括其特定组件、状态和操作逻辑。 它们都应遵循以下结构。 您可以在模块中嵌套模块(称为子模块),同样的规则将适用。上下文
上下文是一种通过组件树传递数据的方法,不必在每个级别手动传 props。 详情请参阅 React Context。GraphQL
包含片段、查询和变更。 详情请参阅 GraphQL。- 片段
- 查询
- 变更
钩子
详情请参阅 Hooks。状态
包含状态管理逻辑。 RecoilJS 处理这部分。- 选择器:详情请参阅 RecoilJS Selectors。
工具
应仅包含可重用的纯函数。 否则,请在hooks 文件夹中创建自定义钩子。
UI
包含应用程序中使用的所有可重用的 UI 组件。 这个文件夹可以包含子文件夹,像data、display、feedback 和 input,用于特定类型的组件。 每个组件都应是自包含和可重用的,以便您可以在应用程序的不同部分使用它。
通过将 UI 组件与 modules 文件夹中的其他组件分开,可以更轻松地保持一致的设计,并在更改 UI 时不影响其他部分(业务逻辑)的代码库。
界面和依赖关系
您可以从任何模块中导入其他模块代码,但ui 文件夹除外。 这将使代码易于测试。
内部
模块的每个部分(钩子、状态等) 都可以有一个internal 文件夹,其中包含仅在模块内使用的部分。