Skip to content

Latest commit

 

History

History
131 lines (87 loc) · 6.02 KB

readme.md

File metadata and controls

131 lines (87 loc) · 6.02 KB

logo

Mili

version downloads license dependencies coveralls

米粒之光,可与皓月争辉

从同一个脚手架衍生出来的项目,很多细节会渐渐变得不一致 也就是说:脚手架对于项目的后续发展失去了控制力。 当我们想要升级一些脚手架的基础功能(例:eslint规则)时,我们不得不去升级每一个项目. 甚至不得不对一些改动过大的项目设计定制化的升级方案。

Mili 提供使用模板来控制项目结构和文件内容的能力,所有使用模板的项目,都必须通过升级模板来实现被控制的文件的变更升级。

如果你们团队管理着多个项目,并希望这些项目具有统一的、可持续迭代的代码规范、基础功能、框架结构,mili非常适合作为你们的脚手架工具。

目录

Usage

创建项目

mkdir my_project
cd my_project

# 来自于NPM仓库的模板
npx mili init npm:@mtpl/code-style
# 来自于GitHub仓库的模板
npx mili init github:mili-project-manager/mtpl-code-style
# 来自于私有仓库的模板
npx mili init https://github.com/mili-project-manager/mtpl-code-style
# 支持SSH
npx mili init [email protected]:mili-project-manager/mtpl-code-style.git

升级项目

模板升级到latest版本

# 在项目目录下执行
mili upgrade

校验项目文件

配合husky,可以很容易的实现提交前校验项目文件是否符合模版规范。 从而保障项目代码的规范。

在终端运行命令:

npx mili check

输出结果:

mili check

运行npx mili update命令,mili将自动按照diff的提示进行增删,从而符合模版的规范。

正反馈

模版 => 项目

模版的更新都会按照设定的文件升级方案应用到每个使用这个模版的项目中去,减轻每个项目进行升级的工作量。

项目 => 模版

当存在一下情况时:

  1. 被模版的基础功能/结构无法满足项目的业务需求
  2. 模版的文件存在bug

这时候,项目的开发者需要对模版进行更新。因为只有更新到模版后,才能‘安全的’将这些改动应用到项目中来(通过升级模版)。 与此同时,模版 => 项目的反馈也会为所有的项目带来bug升级、新特性、或结构性调整,减少其他项目升级工作量。

Q&A

template的模版非常像是一个依赖包,为什么不将模版提成一个npm包呢?

  1. 其实,模版的一部分功能确实应该抽象成一个库,将打包、发布、公司内部服务甚至server等全部按照统一规范包装成一个库(npm包)。

    但是,这只是理想状况。通常来说,团队始于一个模版,一个项目,逐步发展到多个项目。 经过很长一段时间,总结经验,最终才会形成一个规范的库。 而在这段时间内,将会面临每个项目中实现细节分化的问题。

    最终,在将有一致规范的功能抽象为库的过程中,需要大量改造项目,带来很大的项目改造开发量。

    mili可以在这个过程中起到缓冲作用和辅助升级作用,保证所有项目具有一致的模版。

  2. 有些文件无法抽象到库中,但是还需要在所有项目里统一。例如:issue模版、readme.md的内容结构等东西。 必须要放在项目根目录下才能被识别,但是又需要跟随模版升级、多项目统一。

因此,即使已经将具有统一规范的功能完全的抽象为一个库,依旧有很大的可能,在每个项目下面,存在一些需要多项目统一的文件。

另外,必须要说明的一点是将具有统一规范的部分提取成库与mili并不冲突。往往你提取完成后,得到的依旧是一个简化的轻量级的模版。

对于不同小团队之间的不同开发方式如何做统一

  1. 如果是类似于“代码是否应该使用分号”这类的差异,是佛说佛有理,公说公有理。 但是这类差异“统一”往往比“不统一”更有团队价值。 还有争议更大的如react vs vue

  2. 再一个面临的问题是,当前的web模版并不适合一些团队的小程序类型的应用开发。 这时候可能出现两种办法:

    • 扩展web模版,使其能支持多端开发,可以利用一些write once run everywhere的框架。
    • 开发一个新的模版专门用于规范小程序开发,使得web与小程序分离。保持两方面开发的灵活性。 这就类似于制定法律,往往不止有一个宪法,还会有商品法、房地产管理法等等。

    是用一个模版,还是管理多个模版。需要从灵活性、简单、统一等方面考量出最适合团队的一个综合方案。 但是,保持多个模版中相似规范和框架的一致性是必要的。可以通过开发一个“模版的模版”来实现。

Contributing & Development

如果存在如何疑问,非常欢迎提issue一起讨论。 请在讨论时,遵守Contributor Covenant Code of ConductCONTRIBUTING。 让我们共同维护良好的社区环境。