通用 - 上浮模式

2023-10-19 02:10
文章标签 通用 模式 上浮

本文主要是介绍通用 - 上浮模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

适用范围

组件,hooks,工具函数,style等

优势劣势 

优势:

        1、从数据耦合和使用频率上,规范性约定组件通用上浮机制,方便后续形成自动化

        2、统一引入入口,减少后续组件上浮后整体项目的改造成本

劣势:

        1、统一入口后,若组件过多,可能会导致入口文件的引用数量过多

阶段划分

阶段通过文件夹进行定义:

阶段名称

使用次数

数据解耦

说明

rc1-common

多处复用

通过props传递

自可用状态,复用性已验证,可提取出作为npm包独立使用

rc2-common-candi

仅1处

通过props传递

自可用状态,暂时未确认复用性优劣,待后续验证

rc3-biz

多处复用

依赖全局数据

复用性被验证,但需要考虑对全局数据的解耦

rc4-biz-candi

仅1处

依赖全局数据

暂时未确认复用性优劣,待后续验证。需要考虑对全局数据的解耦

dep-[类型]

仅1处

依赖局部数据

不可自用装态,高耦合于业务模块数据,如store数据

文件命名:dep-[类型],如 dep-components,dep-hooks

文件目录

以组件为例

├──src
│   ├──components
│   │   ├──rc1-common
│   │   │   └──button
│   │   ├──rc2-common-candi
│   │   │   └──table
│   │   ├──rc3-biz
│   │   ├──rc3-biz-candi
│   │   └──index.tsx
│   ├──modules
│   │   ├──plan
│   │   │   ├──dep-components
│   │   │   │   └──table

index.tsx内容,约定所有通用的统一入口,方便后续进行通用性的提升。

export {default as Button} from './rc1-common/button';
export {default as Table} from './rc2-common-candi/table';

针对组件的使用,页面A文件

import {Button} from '@components/index';const A = () => {return (<Button/>)
}    

FAQ

1、rc1-common依赖rc1-common-candi,如何处理?

将rc1-common-candi提升为rc1-common

2、多处使用dep,如何处理?

将dep提升为rc3-biz

 

这篇关于通用 - 上浮模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/236607

相关文章

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

SpringBoot如何通过Map实现策略模式

《SpringBoot如何通过Map实现策略模式》策略模式是一种行为设计模式,它允许在运行时选择算法的行为,在Spring框架中,我们可以利用@Resource注解和Map集合来优雅地实现策略模式,这... 目录前言底层机制解析Spring的集合类型自动装配@Resource注解的行为实现原理使用直接使用M

C#原型模式之如何通过克隆对象来优化创建过程

《C#原型模式之如何通过克隆对象来优化创建过程》原型模式是一种创建型设计模式,通过克隆现有对象来创建新对象,避免重复的创建成本和复杂的初始化过程,它适用于对象创建过程复杂、需要大量相似对象或避免重复初... 目录什么是原型模式?原型模式的工作原理C#中如何实现原型模式?1. 定义原型接口2. 实现原型接口3

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

详解Python中通用工具类与异常处理

《详解Python中通用工具类与异常处理》在Python开发中,编写可重用的工具类和通用的异常处理机制是提高代码质量和开发效率的关键,本文将介绍如何将特定的异常类改写为更通用的ValidationEx... 目录1. 通用异常类:ValidationException2. 通用工具类:Utils3. 示例文

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法

【iOS】MVC模式

MVC模式 MVC模式MVC模式demo MVC模式 MVC模式全称为model(模型)view(视图)controller(控制器),他分为三个不同的层分别负责不同的职责。 View:该层用于存放视图,该层中我们可以对页面及控件进行布局。Model:模型一般都拥有很好的可复用性,在该层中,我们可以统一管理一些数据。Controlller:该层充当一个CPU的功能,即该应用程序