首页 > 其他 > 详细

npm init cabloy背后的故事

时间:2020-01-02 17:52:02      阅读:86      评论:0      收藏:0      [点我收藏+]

背景

我们知道许多框架会提供一个脚手架工具,我们先下载安装脚手架工具,然后再通过脚手架命令行来创建项目。在npm@6.1.0中引入了npm init <initializer>的语法。简单来说就是你执行npm init cabloy的话,npm会补全模块名为create-cabloy,并执行npx create-cabloy

CabloyJS提供的命令

我们知道,在CabloyJS中创建一个项目,使用如下命令:

npm init cabloy cabloy-demo --type=cabloy

在项目中创建一个业务模块,使用如下命令:

npm init cabloy src/module/test-todo --type=module-business

npm init cabloy具体流程

下面我们具体说一下这一行npm init cabloy具体做了哪些事情:

  1. 关于npm init cabloy:npm会自动下载模块create-cabloy,然后执行create-cabloy,顺便把后面的参数传入

  2. 模块create-cabloy会自动执行模块egg-born,顺便把后面的参数传入。(为什么这样跳转一次?是因为egg-born命令行工具早就实现了,而npm init cabloy的机制是npm后期引入的)

    egg-born就是我们在上面提到的脚手架工具

  3. 模块egg-born会下载模块egg-born-init-config

  4. 模块egg-born-init-configpackage.json文件中定义了三个模版:每个模版对应一个npm模块。比如模版module-business对应模块egg-born-template-module-business

  5. 如果用户通过--type指定了module-business,那么就会自动下载模块egg-born-template-module-business

  6. 模块egg-born-template-module-business包含两部分:
    • index.js文件:定义了一些变量,egg-born会使用这些变量收集当前模版的参数,如name/description等等
    • boilerplate目录:包含一套文件模版,egg-born会自动替换文件模版里面的参数,然后输出到预定的目录,在这个例子中就是src/module/test-todo

npm init cabloy背后的故事

原文:https://www.cnblogs.com/zhennann/p/12133710.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!