monorepo-templates
pnpm install -D -w eslint typescript @typescript-eslint/eslint-plugin @typescript-eslint/parser vue-eslint-parser eslint-plugin-jsx-a11y eslint-plugin-react eslint-plugin-react-hooks eslint-plugin-vue
pnpm add -D -w stylelint stylelint-config-standard stylelint-config-recess-order stylelint-config-standard-scss postcss-html postcss-less postcss-scss
pnpm add -D -w postcss postcss-cli postcss-pxtorem postcss-preset-env autoprefixer
pnpm add -D -w git-cz
pnpm add -D -w @commitlint/cli @commitlint/config-conventional commitlint
pnpm add -D -w husky lint-staged standard-version
npx husky add .husky/commit-msg 'npx --no-install commitlint --edit "$1"'
npx husky add .husky/pre-commit "npx lint-staged"
git tag -a v0.03-init -m "release first full function version"
git push --tags
git push --all origin
git fetch --all
git pull --all
添加子模块非常简单,命令如下:
git submodule add <url> <path>
- 其中,url 为子模块的路径,path 为该子模块存储的目录路径。
- 执行成功后,git status 会看到项目中修改了.gitmodules,并增加了一个新文件(为刚刚添加的路径)
- git diff --cached 查看修改内容可以看到增加了子模块,并且新文件下为子模块的提交 hash 摘要
- git commit 提交即完成子模块的添加
克隆项目后,默认子模块目录下无任何内容。需要在项目根目录执行如下命令完成子模块的下载:
git submodule init
git submodule update
或:
git submodule update --init --recursive
执行后,子模块目录下就有了源码,再执行相应的 makefile 即可。
- 子模块的维护者提交了更新后,使用子模块的项目必须手动更新才能包含最新的提交。
- 在项目中,进入到子模块目录下,执行 git pull 更新,查看 git log 查看相应提交。
- 完成后返回到项目目录,可以看到子模块有待提交的更新,使用 git add,提交即可。
有时子模块的项目维护地址发生了变化,或者需要替换子模块,就需要删除原有的子模块。 删除子模块较复杂,步骤如下:
rm -rf #子模块目录 删除子模块目录及源码
vi .gitmodules #删除项目目录下.gitmodules文件中子模块相关条目
vi .git/config #删除配置项中子模块相关条目
rm .git/module/* #删除模块下的子模块目录,每个子模块对应一个目录,注意只删除对应的子模块目录即可
执行完成后,再执行添加子模块命令即可,如果仍然报错,执行如下:
git rm --cached #子模块名称
完成删除后,提交到仓库即可。