脚手架学习

1、为什么全局安装 @vue/cli 后,执行 vue create xxx 命令就能运行?

npm 会将包安装在全局 node_modules 目录中,执行命令时,系统会在 PATH 环境变量列出的目录中查找 vue 可执行文件,这个文件通常位于 @vue/cli/bin/vue.js

@vue/cli 包的 package.json 中定义了安装时能自动创建命令的链接

javascript 复制代码
"bin": {
  "vue": "bin/vue.js"
}

2、执行 vue 命令时发生了什么?为什么 vue 指向一个 js 文件,但 我们却可以通过 vue 命令去执行它?

1、终端首先会在系统的 PATH 环境变量中查找名为 vue 的可执行文件,通过 where vue 命令可以看到;

2、 js 文件能够直接执行是因为文件顶部有 shebang 声明,告诉系统用 node 解释器来执行此脚本

javascript 复制代码
#!/usr/bin/env node

3、当通过 npm 全局安装 @vue/cli 时,npm 会做两件事:1、将包安装到全局 node_modules;

2、在系统的 bin 目录创建软链接指向这个 js 文件

3、脚手架开发流程

创建 npm 项目,创建脚手架入口文件,最上方添加:

javascript 复制代码
#!/usr/bin/env node

配置 package.json,添加 bin 属性

编写脚手架代码,将脚手架发布到 npm

4、脚手架开发难点

1、如何将脚手架的逻辑会拆分为若干个简单的模块

2、如何注册命令,并将注册的命令执行到对应的方法上:vue create、vue add、vue invoke

3、如何设计参数解析( vue command [options] <params>)、帮助文档、命令行交互、日志打印、命令行文字变色、网络通信、文件处理等

5、脚手架本地link标准流程

1、链接本地脚手架:

bash 复制代码
cd your-lib
npm link
cd your-cli
npm link your-lib

npm link 会把 your-lib 链接到 node 下 node_modules 中,然后 your-cli 就可以连接了

2、取消连接本地库文件

bash 复制代码
cd your-lib
npm unlink
cd your-cli
npm unlink your-lib

npm link:将当前项目链接到 node 全局 node_modules 中作为一个库文件,并解析 bin 配置创建可执行文件

npm link your-lib:将当前项目链接到 node 全局 node_moudles 中作为一个库文件,并解析配置创建可执行文件

npm unlink:将当前项目从 node 全局 node_moudles 中移除

npm unlink your-lib:将 your-lib 文件从当前项目中移除

相关推荐
2501_9209317013 分钟前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman052843 分钟前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔44 分钟前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李1 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN1 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒1 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库1 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
方也_arkling1 小时前
Element Plus主题色定制
javascript·sass
电商API_180079052471 小时前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫