我们正在开发一套组件库,欢迎你的加入~

news2025/1/27 12:42:53

image.png

项目地址

github地址
可以先点进来康康~

技术栈

目前我们整体采用的是vue3+typescript+less作为整体的开发的选择

需要说的是,我们并没有采用很多组件库采用的TSX的写法,而是选择了SFC的写法,这是因为我们觉得对于大部分的vue开发者来说,可能template的写法已经深入到大家的开发思想之中,所以我们想让更多的人参与进来,这是我们的一个初衷。

当然,现在有另一群小伙伴已经开始到了React端的建设之中,感谢大家的努力!在vue端建设丰富之后,我们会商讨接下来的计划,来决定要不要团队的一部分人去投入到多端的工作之中,这可能要取决于我们最初组织者的初衷和未来的发展计划。

初衷

我们的组织者是一个UI大大“yike”,这里放一下他的小破站的地址。

这套组件库最开始创建的原因非常简单。就是作为一名设计人员,出于对前端组件的好奇,希望有一套属自己的组件库,用以表达自己的设计。但实践过程中个人的力量终究是有限的,团队的力量是无穷的,现在开源出来期待与大家一起建设它。希望能用团队的力量,不断完善这个项目。

那么,现在就会说到另一个话题:现在组件库这么多,而且基本是几家独大,那么这样做下去的意义在哪里?

这也是我们一开始开会就在讨论的问题,目前我们的计划还是,先开发基础组件,开发完技术组件后,我们会开发一些有意思的功能性组件,类似用户组件登录组件评论组件富文本等等,这也是我们需要先开发基础组件的原因。

我觉得我们和目前主流的组件库侧重点是不一样的,他们是为了将基础的业务组件做到更好,做到一种极致,而我们更多是想开发一些通用性并不那么强的,好玩的一些东西。

我觉得我们是有优势的,毕竟我们有着专业的UI,可以做更好的设计、交互体验以及UI走查,UI设计这也是我们最注重的一点~

项目的重构

我们现在的项目是基于之前的项目重构的,因为之前的项目耦合度较强,规范度是不够的,所以在这两周,我们都是着重于项目的重构计划之中。

我们觉得monorepo的模式是很符合我们这个项目的,所以项目采用了比较主流的monorepo,关于monorepo并不是这篇文章介绍的重点,如果并不是特别了解的小伙伴可以看看相对应的文章。

目录结构

image.png

我们可以先稍微整体地看一下目录

文档

需要说一下的是这个demo的工程

image.png

这个demo工程主要是用来存放项目的文档,这里需要说的是,我们之所以没有采用vitepress或者是vuepress来快速建站是因为文档在最开始已经由我们的yike设计并创建好了,当初是比较费心费力的,而且我们如果用vitepress的话,可能也会进行大量的样式更改,所以干脆保留了最初的这个方案,并进行文档方面的维护。

这里也给大家展示一下文档效果


image.png

image.png

image.png

image.png

并且文档也有着对应的书写规范,文档是由大飞hxd来创建规范和管理的,我们一致认为他做的非常好!

文档目录结构


文档目录应该按照以下结构进行组织:

- /demo/src/examples/button: 根目录,包含组件示例和文档
  |- /button: 按钮组件目录
    |- doc.md: 按钮组件文档
    |- button-example1.vue: 按钮组件示例文件1
    |- button-example2.vue: 按钮组件示例文件2
    |- ...
  |- /component2: 第二个组件目录
    |- doc.md: 第二个组件文档
    |- component2-example1.vue: 第二个组件示例文件1
    |- component2-example2.vue: 第二个组件示例文件2
    |- ...

每个组件目录下都应该包含一个 doc.md 文件和若干示例文件

组件文档 doc.md


组件文档使用 Markdown 格式编写,提供关于组件的说明、用法、API 等相关信息。以下是一个组件文档的基本结构示例:

### yk-button 按钮  (文档首页标题)


:::snippet  (每个demo对应信息采用 :::snippet::: 标志位进行维护)
按钮类型 type
按钮有三种类型:`主按钮` 、`次按钮` 、`线框按钮` 。主按钮在同一个操作区域建议最多出现一次。
<ButtonPrimary/>
:::

:::snippet 
按钮尺寸 size
按钮分为:`s`、`m`、`l`、`xl` 四种尺寸。高度分别为:`24px`、`32px`、`36px`、`48px`。默认尺寸为 l。
<ButtonSize/>
:::

:::snippet 
title
desc
<DemoFileName/>
:::
...

### API (API标题)

通过设置 Button 的属性来产生不同的按钮样式,推荐顺序为:type -> size -> shape -> status -> disabled。 (API说明)

|参数      | 描述     | 类型     | 默认值 | (md表格结构)
| ------------------ | ----------------- | ---------------| ---------------- |
| type | 按钮的类型   | 'primary'或'secondary'或'outline'   | primary |
| 单元格信息 | 单元格信息 | 单元格信息 | 单元格信息 |
| 单元格信息 | 单元格信息 | 单元格信息 | 单元格信息 |
  • 每个demo对应信息采用 :::snippet::: 标志位进行维护

  • 单个demo在doc.md中维护的信息有

    • Title: demo标题,说明该组组件demo共性
    • Desc: demo说明,支持md格式
    • DemoName demo名称,采用驼峰命名法的单标签,必须为文档目录下存在的文件,否则可能存在解析报错
  • 每个demo文件只可在doc.md中引入一次

md文档加入vue-router


{
  path: 'button',
  component: () => import('@/example/button/doc.md'),
 },

对应效果


补充


7.10日新增 :::pure::: 标记符号,该标记位将直接渲染内部demo组件并自动引入相关依赖,具体用例如下

### 线性图标展示
复制对应图标下的名称获取该图标。
:::pure
<IconPrimary/>
:::

应用效果

yk-design-ui主工程

然后在packages下就是我们主要的组件库工程了

image.png

目前我们暂定的目录结构如下

image.png

当然,我们现在的工程已经基于目录结构进行了一些展开的工作

比如我们对样式已经做了进一步的抽离,以及一些公共的type我们也放到了constant.ts

image.png

image.png

并且我们已经对每个组件的props进行了类型的抽离,并且现在已经在书写时已经有了良好的类型提示。

我们觉得一些良好的代码设计,可以在巨人的肩膀上进行下一步工作,比如我们会借鉴element-plus的很多处理方式,但是我们并不会完全地去抄他的业务代码,这没有什么意义。

需要提一下的是,我们虽然有单元测试的计划,但是目前被搁置了,因为我们还是打算全部都迁移完成之后,再去进行细致的工作,而单元测试我已经集成了vitest,它十分的简单,大家也可以快速地进行学习。在接下来的工作中,我们会考虑开始进行单测工作。

代码规范化工作

其实我们并没有做特别多的代码规范化的工作,但是我们仍然对一些必要性的规范有一定的要求

  • eslint
  • prettier
  • stylelint
  • commitlint
  • pr规范

这些配置我们已经配置完了,现在只需要大家在书写的时候进行检查工作即可,并且在pr的时候注意一下提交的规范即可

我们目前并没有做更多的工作,比如强制你去使用pnpm,强制走单测等。为此也是希望更多的人能够参与进来,但是我们仍希望你对自己是有规范要求的,比如良好的代码风格,BEM规范等等,那么这会减少我们去审核pr的时间。

接下来的工作计划

我们的开发工作有团队基于飞书的文档,也有着供大家可看的在线的腾讯文档,并且也在CoDesign上放置了设计稿。

image.png

image.png

image.png

现在我们还是在进行组件的迁移工作,但是已经有很多小伙伴已经开发了新的组件,我们也在积极地审核pr。

在近两天我会完成所有打包的工作,并且去考虑发布到npm上,让大家更方便地去使用。

预计这两周所有组件迁移完成的前提下,可能会开发一些新的组件,当然,这需要大家共同的努力!

并且在新一轮的工作中,我会单开出一个分支进行单元测试,保证良好的单元测试覆盖率。

在这周我们会重新书写一下README文件,当然,这都是小事啦。

并且我们这两周会进行开会,讨论接下来的发展任务,可能会单开出分支,由一部分人用来开发功能性组件,另一部分继续基础组件的开发过工作,但是,在这个过程中,可能需要yike进行比较高强度的设计工作,所以我们也希望,如果你有UI的功底的话,也可以加入进来!

我们深知这个项目是有很多不足的!我们的开发能力是有限的,有UI,有在校学生,大部分的人,并没有多年的开发经验和代码实力,我们也知道有着很多需要改进的地方,但是我们的目标是一致的!所以我们更多的是抱着学习的态度,来听从大家的建议!更加希望如果你有这个实力并且也有这个想法的话,来加入我们,甚至提一下issuepr都是很好的!

致谢

感谢大家这段时间以来的工作,大部分成员都是把自己的业余时间都拿出来来做这个项目,当然,我这里也不一一去提了,Contributions里面写的也是比较清晰的!

希望大家继续努力,让这个项目继续发酵下去!

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

用得最多的企业文件加密软件【企业文件加密软件前十】

企业文件加密软件是一种专门设计用于保护企业敏感信息的软件工具。它通过使用加密算法将企业的文件、文件夹和移动设备上的数据转化为不可读的格式&#xff0c;以防止未经授权的访问和数据泄露。这些软件通常提供了多种加密算法和安全控制选项&#xff0c;以满足不同企业的安全…

国外访问学者博士后常用的网络视频面试软件

面试是获得邀请函的重要环节&#xff0c;随着网络的广泛应用&#xff0c;现在视频面试逐渐取代了电话面试&#xff0c;本篇知识人网小编介绍几种国外访问学者博士后常用的网络视频软件。 在申请国外博士后或者访问学者职位时&#xff0c;当接收方导师收到CV&#xff08;简历&am…

postgis上传 上千个资源文件

需求背景所需工具解决流程1. 获取文件名信息2.复制到 excel 表格中3.转成 csv 文件 需求背景 需要把上千个文件资源上传到远端&#xff0c;并建立数据表 所需工具 Notepad 7wps office 11.1.0 解决流程 1. 获取文件名信息 复制文件路径&#xff0c;在 cmd 中进到文件夹&…

Python程序设计基础:列表与元组(二)

文章目录 一、数值列表的生成1、通过input()函数输入创建列表2、通过list()函数转换3、列表生成式4、数值列表的几种统计计算 二、元组1、元组的定义2、元组的操作3、元组作为列表元素 三、转换函数1、元组和列表之间的转换2、字符串和列表之间的转换3、split()方法 一、数值列…

深度学习模型:Pytorch搭建ResNet、DenseNet网络,完成一维数据分类任务

2023.7.17 DenseNet和ResNet都是深度学习中常用的网络结构&#xff0c;它们各有优缺点。 DenseNet的优点是可以充分利用网络中的信息&#xff0c;因为每个层都可以接收来自前面所有层的信息。这种密集连接的结构可以提高网络的准确性&#xff0c;减少过拟合的风险。此外&…

教你一招,动态规划思想

动态规划 什么是动态规划&#xff1f; 动态规划也是算法设计的一种方法/思想。它将一个问题分解为相互重叠的子问题&#xff0c;通过反复求解子问题&#xff0c;来解决原来的问题。 基础案例 场景一 斐波那契数列 当前数等于前面两个数的和。 定义子问题&#xff1a;f(n)…

Python异步网络编程框架Twisted使用方法

Twisted概念 Twisted是一个Python异步网络编程框架&#xff0c;它可以帮助我们开发高性能的网络应用程序。它提供了一些基本概念&#xff0c;如reactor、protocol、transport和factory等&#xff0c;用于构建高效的网络应用程序。 优点&#xff1a; 异步并发处理&#xff1a…

Ceph集群

目录 一、存储概述 1.单机存储设备 1.1 DAS 1.2 NAS 1.3 SAN 2. 单机存储的问题 3. 商业存储解决方案 4.分布式存储&#xff08;软件定义的存储 SDS&#xff09; 4.1 分布式存储的类型 二、Ceph简介 1.Ceph 优势 2. Ceph 架构 2.1 RADOS 基础存储系统 2.2 LIBRADOS…

Arch - 多线程设计架构模式

文章目录 概述细节 概述 多线程设计架构模式是一种通过合理地使用线程来提高系统性能和响应能力的设计模式。以下是一些常见的多线程设计架构模式&#xff1a; 线程池模式&#xff1a;通过预先创建一组线程&#xff0c;将任务提交到线程池中执行&#xff0c;避免了线程的频繁创…

Perforce Helix Core新版本推出资源压力感知功能,提升服务器可用性,助力大规模开发

您的版本控制系统帮助团队进行主动监控吗&#xff1f; Perforce Helix Core的客户经常在不同维度上测试规模和性能的极限。其中一些维度包括文件数量、文件大小、用户数和并发事务数量。随着这些维度的压力增加&#xff0c;服务器资源&#xff08;如内存和CPU&#xff09;通常…

时刻领先丨PingCAP 用户峰会 2023 圆满收官

7 月 13 日&#xff0c;PingCAP 用户峰会 2023 在北京西南华邑酒店成功举办。 大会有哪些精彩看点&#xff0c;快跟小编来看看吧&#xff01; 提升中国开源数据库在国际市场的影响力和竞争力 倪光南 中国工程院院士 在全球数字科技创新的浪潮中&#xff0c;数据库作为核心数…

EVO 工具常见使用记录

计算ATE 第一种 evo_ape tum GT_robot_0.txt robot0_estimated.txt --plot --plot_mode xyz --align_origin第二种 evo_ape tum GT_robot_0.txt robot0_estimated.txt --plot --plot_mode xyz -a参数解析 GT pose 跟 estimated pose 文件的相对顺序。先 GT pose 的文件…

Boojum:zkSync的高性能去中心化STARK证明系统

1. 引言 2023年7月17日zkSync官方twitter Say hello to Boojum宣称在不regenesis的情况下&#xff0c;将zkSync Era迁移至Boojum证明系统。 Boojum为STARK证明系统&#xff08;PlonkFRI&#xff09;&#xff0c;开源代码见&#xff1a; https://github.com/matter-labs/era-…

【kubernetes系列】Kubernetes之调度器和调度过程

Kubernetes之调度器和调度过程 概述 当用户请求向API server创建新的Pod时&#xff0c;API server检查授权、权限等没有任何问题的话&#xff0c;他会把这个请求交由Scheduler&#xff0c;由Scheduler检查所有符合该Pod要求的列表&#xff0c;开始执行Pod调度逻辑&#xff0c…

mongdb基本操作

如果要查看刚刚创建的数据库 创建集合class 将数据插入 进行查找练习 查看班级所有人信息 db.class.find()查看班级中年龄为10岁的学生信息 db.class.find({age:10})查看年龄大于10岁的学生信息 用到范围条件查询 db.class.find({age:{$gt:10}})查看年龄在 4—8岁之间的学…

Jetpack入门:DataBinding

目录 一、DataBinding简介 设置 Data Binding 数据绑定表达式 双向绑定 二、例子 例1&#xff1a;DataBinding实现文本绑定和点击事件 MainActivity &#xff1a; CountStart &#xff1a; Food: OnClickListener &#xff1a; activity_main: build.gradle: 运行结果…

用vscode远程连接Linux服务器后,如何创建自己的账号

1. 打开终端&#xff08;Terminal&#xff09;窗口 2. 在终端中创建新的用户账号 &#xff08;假设您要创建的用户名为 “newuser”&#xff09;&#xff0c;在命令执行期间&#xff0c;需要提供新用户的密码。按照提示进行操作。 先输入登录的管理员账号密码。 再输入创建的…

2.2 Entry Text输入,文本框

2.2 Entry & Text输入&#xff0c;文本框 窗口主体框架 每一个tkinter应用的主体框架都包含以下几部分&#xff1a; 主窗口: window&#xff0c;及主窗口的一些基本属性&#xff08;标题、大小&#xff09;让窗口活起来&#xff1a;window.mainloop() import tkinter as…

热插拔-udev机制

一、什么是udev&#xff1f; udev是一种设备管理工具&#xff0c;以“守护进程”的形式运行&#xff0c;通过侦听内核发出来的uevent来管理/dev目录下的设备文件。它能够根据系统中的硬件设备的状态动态更新设备文件&#xff0c;包括设备文件的创建&#xff0c;删除等。使用ud…

线程池学习(二)execute() 和 submit() 的区别

转载&#xff1a;线程池 线程提交的两种方式 ExecutorService poll3 Executors.newCachedThreadPool();for (int i 0; i < 2; i) {poll3.execute(new TargetTask());poll3.submit(new TargetTask());}execute方法 void execute(Runnable command): Executor接口中的方法s…