2.8.3 • Published 7 days ago

@aloudata/aloudata-design v2.8.3

Weekly downloads
-
License
MIT
Repository
-
Last release
7 days ago

组件库开发规范

简介

本文档用于介绍组件库开发相关的规范以及组件库开发过程中的注意事项。

环境配置

组件库开发过程中,需要满足以下条件:

Node version >= 16.0.0

组件库介绍

1 快速开始

安装和启动

  git clone https://codeup.aliyun.com/60dd34bf4690c27532d3d021/fe/aloudata-design.git
  cd aloudata-design
  yarn install
  yarn start

创建组件模板

  yarn run cmt //根据指令输入组件名称,创建组件开发模板

组件校验

  yarn run lint //stylelint、eslint 校验

组件测试

  yarn run test //单元测试

组件打包

  yarn run build //打包

组件本地link

  npm link //将组件库link到本地npm
  // 切换到业务项目目录,·引入组件库
  npm link @aloudata/aloudata-design // 业务项目中引入组件库

2 目录结构

.
├── README.md --> readme
├── docs --> 文档目录
│   └── index.md
├── scripts --> 自定义脚本目录
│   └── createComponentTemplate.mjs
├── dist --> 组件打包生成的组件目录
├── src --> 组件目录
├── tsconfig.json --> tsconfig ts配置文件
├── .editorconfig 
├── .eslintrc.js  --> eslint ts等校验规则配置
├── .fatherrc.ts  ---> father组件打包配置
├── .prettierrc.js ---> prettier 代码格式化配置
├── .stylelintrc.json ---> less 校验规则配置
├── .umirc.js          ---> 脚手架配置
├── commitlint.config.js --> commit 配置规则
├── typings.d.ts
├── package-lock.json
├── package.json
├── yarn-error.log
└── yarn.lock

3 代码风格

我们使用eslint+stylelint+prettier 来统一代码风格,同时需要对vscode做一定的配置,具体配置参考

ts文件使用 eslint 校验, 配置文件 .eslintrc.js 查看规则 less文件使用 stylelint 校验, 配置文件 .stylelintrc.json 查看规则 使用 prettier 格式化代码,配置文件 .prettierrc.js

组件开发指南(必读)

了解组件分类

  1. 毛坯组件 原始的未做任何修改的antd组件
  2. 简装组件 是指在毛坯组件的基础上,只简单了修改了一些颜色、样式等的组件
  3. 精装组件 所谓精装组件,是指设计师精心设计过组件应用场景和UI的组件,可能基于antd,也可以完全自定义

单元测试

组件开发过程中需要写单测的,建议先写单测,然后进行开发。了解TDD

哪些情况需要写单元测试:

  1. 如果是基于antd的组件,但凡组件有api接口变动,必须要写单元测试
  2. 非基于antd的组件,必须要写单元测试
  3. 单元测试需要覆盖组件每一个api接口的各个状态
  4. 单元测试文件以 .test.tsx 结尾

单元测试参考资料:

组件开发注意事项

组件开发支持两种模式,基于antd开发和其它自定义开发。

基于antd开发: 在业务满足的情况下,建议基于antd开发或者rc组件开发。方式是把antd组件引用过来,然后做升级修改之后,再作为ald组件暴露出去

自定义开发: 当antd组件不满足业务的时候,可以自定义开发,允许引用其它基础组件进行二次开发或者完全自定义组件进行开发。通常是精装组件。

组件开发有以下几个必须要注意的点

  1. 组件样式要和组件类进行分离,即在组件开发的过程中,不允许引用css、less等样式组件。样式单独写在style文件夹下。
  2. 组件文档内的api接口展示,是获取组件属性props的接口interface定义来实现的(自定义md表格除外)。组件库脚手架对于组件接口interface有处理,即凡是接口来自于外部库引入的部分,不会被文档api识别,即无法展示。interface接口的每一个想要暴露的属性,都必须要写注释,主要包括类型、描述、默认值等。
  3. 组件简装及以上,必须要写demo样例,用于展示已经支持的样式及功能
  4. 精装组件必须要写单元测试。每一个组件的属性,都要在测例中进行测试,保证在组件的的维护修改过程中,不会出现bug。
  5. 组件由ts编写,必须对外暴露所有可能在业务使用过程中需要的ts类型。
  6. 组件库不使用css-module,请考虑权重问题,禁止出现 !important 这样的样式

组件库文档编写注意事项

文档前文frontMatter编写

在组件库官网展示的时候,会根据文档头部的信息,对文档进行分类,我们当前的计划是分成三类:设计、文档、组件;

在文档头部,使用YAML预发进行编写,用于描述组件的文档的信息,如:

---
nav:
  title: 组件
  path: /components
title: Select 选择器
group:
  title: 组件
---

具体参考:FrontMatter

组件场景用例demo展示

每个简装以上组件都需要展示场景用例,写在src/**/demos/文件夹下 demo项目中,像在业务中使用aloudata-design一样,脚手架会自动关联项目到node-modules下。(建议先build一下,然后再进行demo展示) 在组件的md文档中使用code引入用例,在文档中展示用例,如:

<code src="./demos/single/index.tsx" title="单项选择"/>

关于demo的配置,即code的用法,请参考demo配置

组件api展示

api展示为表格形势,可以使用API标签,如:

  <API src="/path/to/your/component.tsx" hideTitle></API>

参考文档:API

也可以自己使用md语法写表格

| 属性 | 描述 | 类型 | 默认值 |
| ---- | ---- | ---- | ---- |
| value | 某个值 | string | 当前选中的值 |

关于组件模板创建

使用 npm run cmt 创建的组件模板只是做一个参考,需要自己根据实际需求进行修改

关于组件库打包

一、组件打包

  npm run build

组件打包的入口在src/index.tsx,必须在文件总暴露出来,组件才会被打包。 组件打包使用umi框架的 falter 打包工具, 具体配置在 .fatherrc.ts中。打包后会生成lib目录,es目录。

二、官方网站打包

  npm run docs:build

官网打包我们默认使用dumi站点模式,会分为设计、文档、组件三个版块,其中设计和文档版块的内容在docs目录下,组件版块的内容在src/*/.test.md文件中。

  1. 设计部分用于描述组件的设计理念,内容由设计师提供,可以是链接,也可以是资料等。
  2. 文档用于描述组件库开发的一些信息等。
  3. 组件用于展示组件的使用场景用例,组件的一些信息,组件的api接口等

按需引用

[
    'import',
    {
      libraryName: '@aloudata/aloudata-design',
      libraryDirectory: 'dist',
      style:(name)=>{
        return `${name}/style/index.less`
      },
      camel2DashComponentName: false,
    },
]
2.8.3

7 days ago

2.8.2

11 days ago

2.8.1

22 days ago

2.8.0

24 days ago

2.7.6

30 days ago

2.7.7

30 days ago

2.7.5

1 month ago

2.7.4

1 month ago

2.7.3

1 month ago

2.7.2

1 month ago

2.7.1

2 months ago

2.7.0

2 months ago

2.6.3

2 months ago

2.6.2

2 months ago

2.6.1

2 months ago

2.6.0

2 months ago

2.5.2

3 months ago

2.5.1

3 months ago

2.5.0

4 months ago

2.4.1

4 months ago

2.4.0

4 months ago

2.3.0

4 months ago

2.2.0

4 months ago

2.1.0

5 months ago

2.0.5

5 months ago

2.0.4

5 months ago

2.0.3

5 months ago

2.0.2

5 months ago

2.0.1

5 months ago

2.0.0

5 months ago

2.0.0-beta.15

5 months ago

2.0.0-beta.9

5 months ago

2.0.0-beta.8

5 months ago

2.0.0-beta.11

5 months ago

2.0.0-beta.10

5 months ago

2.0.0-beta.14

5 months ago

2.0.0-beta.13

5 months ago

2.0.0-beta.12

5 months ago

2.0.0-beta.7

5 months ago

2.0.0-beta.2

6 months ago

2.0.0-beta.1

6 months ago

2.0.0-beta.6

5 months ago

2.0.0-beta.5

6 months ago

2.0.0-beta.4

6 months ago

2.0.0-beta.3

6 months ago

1.10.14

6 months ago

1.10.5

7 months ago

1.10.4

7 months ago

1.10.3

7 months ago

1.10.2

7 months ago

1.10.9

7 months ago

1.10.8

7 months ago

1.10.7

7 months ago

1.10.6

7 months ago

1.6.4

9 months ago

1.6.3

9 months ago

1.6.2

9 months ago

1.6.1

9 months ago

1.6.0

9 months ago

1.9.17

8 months ago

1.9.16

8 months ago

1.9.15

8 months ago

1.9.14

8 months ago

1.9.13

8 months ago

1.9.12

9 months ago

1.9.11

9 months ago

1.9.10

9 months ago

1.9.1

9 months ago

1.9.0

9 months ago

1.5.4

10 months ago

1.5.3

10 months ago

1.5.2

10 months ago

1.5.1

10 months ago

1.5.0

10 months ago

1.10.1

7 months ago

1.10.0

7 months ago

1.8.1

9 months ago

1.8.0

9 months ago

1.4.3

10 months ago

1.4.2

10 months ago

1.4.1

10 months ago

1.4.0

10 months ago

1.9.8

9 months ago

1.9.7

9 months ago

1.9.6

9 months ago

1.9.5

9 months ago

1.9.4

9 months ago

1.9.3

9 months ago

1.9.2

9 months ago

1.7.0

9 months ago

1.3.1

10 months ago

1.10.13

7 months ago

1.10.11

7 months ago

1.10.12

7 months ago

1.10.10

7 months ago

1.3.0

10 months ago

1.2.0

11 months ago

1.2.1

10 months ago

1.1.1

11 months ago

1.1.3

11 months ago

1.1.2

11 months ago

1.0.2

1 year ago

1.0.9

12 months ago

1.0.8

12 months ago

1.0.7

12 months ago

1.0.6

12 months ago

1.0.5

1 year ago

1.0.4

1 year ago

1.0.3

1 year ago

1.1.0

12 months ago

1.0.1

1 year ago

1.0.0

1 year ago

0.4.9

1 year ago

0.4.8

1 year ago

0.4.8-beta.13

1 year ago

0.4.8-beta.12

1 year ago

0.4.8-beta.11

1 year ago

0.4.8-beta.10

1 year ago

0.4.8-beta.16

1 year ago

0.4.8-beta.15

1 year ago

0.4.8-beta.14

1 year ago

0.4.8-beta.8

1 year ago

0.4.8-beta.7

1 year ago

0.4.8-beta.6

1 year ago

0.4.8-beta.5

1 year ago

0.4.8-beta.4

1 year ago

0.4.8-beta.3

1 year ago

0.4.8-beta.2

1 year ago

0.4.8-beta.1

1 year ago

0.4.8-beta.9

1 year ago

0.4.10

1 year ago

0.4.4

1 year ago

0.4.7

1 year ago

0.4.6

1 year ago

0.4.1

1 year ago

0.4.0

1 year ago

0.4.3

1 year ago

0.4.2

1 year ago

0.4.0-beta.12

1 year ago

0.4.0-beta.11

1 year ago

0.4.0-beta.10

1 year ago

0.4.0-beta.9

1 year ago

0.4.0-beta.5

2 years ago

0.4.0-beta.6

2 years ago

0.4.0-beta.7

2 years ago

0.4.0-beta.8

1 year ago

0.4.0-beta.1

2 years ago

0.4.0-beta.2

2 years ago

0.4.0-beta.3

2 years ago

0.4.0-beta.4

2 years ago

0.3.5

2 years ago

0.2.0-beta.22

2 years ago

0.3.0

2 years ago

0.2.1

2 years ago

0.3.0-beta.1

2 years ago

0.1.1

2 years ago

0.2.7

2 years ago

0.2.6

2 years ago

0.3.2

2 years ago

0.2.3

2 years ago

0.3.1

2 years ago

0.2.2

2 years ago

0.3.4

2 years ago

0.2.5

2 years ago

0.3.3

2 years ago

0.2.4

2 years ago

0.2.0-beta.20

2 years ago

0.2.0-beta.21

2 years ago

0.2.0-beta.2

2 years ago

0.2.0-beta.1

2 years ago

0.2.0-beta.6

2 years ago

0.2.0-beta.5

2 years ago

0.2.0-beta.4

2 years ago

0.2.0-beta.3

2 years ago

0.2.0-beta.9

2 years ago

0.2.0-beta.8

2 years ago

0.2.0-beta.7

2 years ago

0.2.0-beta.10

2 years ago

0.2.0-beta.11

2 years ago

0.2.0-beta.12

2 years ago

0.2.0-beta.13

2 years ago

0.2.0-beta.14

2 years ago

0.2.0-beta.15

2 years ago

0.2.0-beta.16

2 years ago

0.2.0-beta.17

2 years ago

0.2.0-beta.18

2 years ago

0.2.0-beta.19

2 years ago

0.1.0-beta.4

2 years ago

0.1.0-beta.3

2 years ago

0.1.0-beta.2

2 years ago

0.1.0-beta1

2 years ago