Hello, I’m JL๐
Growing up together is my pursuit all the time! โจ
Hope the following share can let you gain ๐ฆ
background
Git, as the most popular open source distributed version control system, is used to handle any project, small or large, with agility and efficiency.
At present, the mainstream version management of the company is using Git or SVN. However, because of its distributed characteristics, Git supports offline and local work, even though the operation is more complicated than SVN, it does not hinder the public’s praise.
However, with the expansion of the project, a project may be developed by many people, and each person’s code style is different, how to achieve git standard management is a relatively common problem.
Git requires that commit information be stored in the commit history as a description of changes. The standard log is not only helpful for others to review, but also can effectively output CHANGELOG, and even greatly improve the quality of project research and development.
Commitlint what is Commitlint?
Git repositories and Workflow are important in multi-person development situations. Git commitlint + husky git commitlint -m “”
Git commmit -m 'XXX' : git commmit -m 'XXX' : git commmit -m 'XXX'Copy the code
How to embed harmoniously in daily projects (for VUe-CLI projects)
The steps are simple:
-
Vue add Commitlint: Add the COMMITlint plug-in. Yes
-
How to determine the successful installation?
After installation, the configuration file commitlint.config.js, or.commitlintrc.js, appears in the root directory
The package.json file appears with the following code:
The installation is successful.
- Add rules commitlint. Config. Js
// Commitlint.config.js module. Exports = {extends: ["@commitlint/config-conventional"], // Commitlint.config.js module. Exports = {extends: ["@commitlint/config-conventional"], // Commitlint: {"type-enum": [2, "always", ['build', // modify the build package 'chore', // modify the build process or helper 'docs', // documentation 'feat', // New feature 'fix', // bug 'perf', // performance optimization 'refactor', // refactor (ie not new feature, 'revert', 'style', 'test' // add tests ',], 'type-case' : [0], 'type-empty' : 'revert', 'style', 'test' // add tests ',], 'type-case' : [0], 'type-empty' : [0], "scope-empty": [0], "scope-case": [0], "subject-full-stop": [0, "never"], "subject-case": [0, "never"], "header-max-length": [0, "always", 72], }, };Copy the code
Of course, more rules can learn about the official documentation themselves
rendering
It can be said that hard insert, non-standard code is submitted! Delicious ~ ๐คฆ came ๏ธ
Commmit specification
Among the popular approaches today are Conventional Commits, which are inspired by, and in large part based on, Angular Commits:
Format: < type >[Optional scope]: < description > // Note that the colon is followed by a space type: 'Build ', // Modify the build package 'chore', // Change the build process or helper tools 'docs', // documentation 'feat', // new feature 'fix', // Fix bug 'perf', // optimize performance 'refactor', // refactor (i.e. not new features, Also not bug code changes) 'revert', // revert previous submissions 'style', // format (changes that do not affect code operation) 'test' // add testsCopy the code
Have a problem
1. Lint failure
Mue-cli has already configured Lint-staged initialization projects. When git COMMIT is performed, the project will execute NPM run Lint first to avoid incorrect commit.
However, after installing Husky (commitLint automatically installing Husky), Lint-passage failed, probably because Husky was used as a Git hooks tool. Hooks are used to execute custom scripts on Git, so hooks are transferred to Husky. After testing, pre-commit on gitHooks can be copied to hooks on Husky.
"GitHooks ": {"pre-commit":" lint-passage "}, "husky": {// Hooks": {"commit-msg": {" precommit ": "lint-passage"}, "husky": {// hooks": {"commit-msg": { "Commitlint-e HUSKY_GIT_PARAMS", // after loading "pre-commit": "Lint - staged", / / failure to add add lint - staged here}}, "lint - staged" : {"/SRC / * * *. {js, vue} ": [" NPM run lint"]}.Copy the code
conclusion
Hope to bring you help โจ~
Share is not easy, praise to encourage ๐ค