Lerna简介
Lerna是一个优化基于git + npm的多package项目的管理工具
优势
- 大幅减少重复操作
- 提升操作的标准化
Lerna是架构优化的产物,它揭示一个架构真理:项目复杂度提升后,就需要对项目进行架构优化。架构优化的主要目标往往都是以效能为核心。
官网
案例
使用Lerna管理的大型项目:
- babel:https://github.com/babel/babel
- vue-cli:https://github.com/vuejs/vue-cli
- create-react-app:https://github.com/facebook/create-react-app
data:image/s3,"s3://crabby-images/4df44/4df440fc66697239b5a3402a0b32153889a770a6" alt=""
lerna命令
-
查看帮助文档:lerna add -h
-
初始化:lerna init
-
创建包:lerna create core
创建core包
-
清除依赖:lerna clean
-
安装到指定的目录下:lerna add @imooc-cli/utils packages/core/
-
重装依赖:lerna bootstrap
-
链接依赖:lerna link
-
删除所有的packages下的所有node_modules:lerna exec -- rm -rf node_modules/
-
查看版本:lerna version
-
哪些packages做了变更:lerna changed
-
lerna diff
-
发布
登录npm:npm login
执行npm login
执行npm publish发包到npm上:lerna publish
执行npm publish发包到npm上
查看是否发布成功
data:image/s3,"s3://crabby-images/2996b/2996b91205a25e2904ae99bc6287865bac020354" alt=""
查看当前登录的用户:npm whoami
- 删除指定的依赖
npm remove -g @hjy-cli/utils
Lerna源码分析
源码仓库地址:https://github.com/lerna/lerna
Lerna启动命令 core/lerna/cli.js ls
data:image/s3,"s3://crabby-images/c4ee3/c4ee36e52a6bfa4670107d639f0ed4be7375e6b9" alt=""
debug
Step Over F10:一行一行往下执行(不会进入importLocal方法里)
data:image/s3,"s3://crabby-images/66d66/66d669f7e66b902195c6e98cb2932bd07ead848d" alt=""
Step Into F11:进入到函数里面执行(会进入到importLocal方法里面)
data:image/s3,"s3://crabby-images/4c166/4c166f023dc7ec2908cd67adb603781afaab4fcd" alt=""
Step Out F8:进入到函数里,不希望再往里面跳,可以跳出来(与F11相反)
Evaluate Expression 实时运算
data:image/s3,"s3://crabby-images/8a601/8a601631d49fbc1676c18441bdca611d0df3b285" alt=""
data:image/s3,"s3://crabby-images/882e0/882e06fe3d3be30a53e6a1da0f72768129e7b570" alt=""
Resume Program 直接跳到对应断点位置
data:image/s3,"s3://crabby-images/62090/6209023b59234c6cf4411ba40fcdca490edac3cb" alt=""
网友评论