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:

  1. Vue add Commitlint: Add the COMMITlint plug-in. Yes

  2. 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.

  1. 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 ๐Ÿคž