whincwu's Blog

Web 前端项目必备配置

2019年07月30日 02:53:54

本文介绍一些前端项目的通用配置及相关资源,以便你了解项目中常见配置的含义以及配置方式。

目录

  • .gitignore - 让 Git 提交时忽略文件
  • editorconfig - 让编辑器或IDEs保持一致的编码样式
  • commitzen - - 交互式生成 Angular 风格的 Git 提交消息
  • Prettier - 美化代码格式
  • ESLint - 检查 JS 代码质量
  • Stylelint - 检查 CSS 代码质量

.gitignore - 让 Git 提交时忽略文件

通过.gitignore文件可将项目中符合规则的文件忽略掉,避免提交带有敏感信息或不需要共享的文件到 Git 仓库。

JavaScript 项目常用配置:

# dependencies
/node_modules

# testing
/coverage

# production
/build

# vscode
.vscode/*
!.vscode/settings.json
!.vscode/tasks.json
!.vscode/launch.json
!.vscode/extensions.json

# env
.env.local
.env.*.local

# misc
.DS_Store

# package manager
npm-debug.log*
yarn-debug.log*
yarn-error.log*

gitignore 是 Github 官方维护的一份 git ignore 配置,可从中查找所需配置规则。

.editorconfig - 让编辑器或IDEs保持一致的编码样式

EditorConfig可以帮助在不同的编辑器和IDE上从事同一项目的多个开发人员保持一致的编码样式。 EditorConfig项目包括一个用于定义编码样式的文件格式和一个文本编辑器插件集合,这些文本编辑器插件使编辑器可以读取文件格式并遵循定义的样式。 EditorConfig文件易于阅读,并且可以与版本控制系统很好地协同工作。

配置示例:

# editorconfig.org
root = true
 
[*]
indent_style = space
indent_size = 2
end_of_line = lf
charset = utf-8
trim_trailing_whitespace = true
insert_final_newline = true
 
[*.md]
trim_trailing_whitespace = false

更多配置参考 EditorConfig

commitizen - 交互式生成 Angular 风格的 Git 提交消息

使用 Commitizen 进行提交时,系统会提示您在提交时填写所有必需的提交字段,你只需要根据提示填写提交信息,Commitizen 会保证最终提交的消息符合 Angular Commit Message Conventions 格式。

snapshot

如果你的项目是对 Commitizen 友好的(即已经安装了 Commitizen 依赖),则在项目下提交消息时可直接使用npx git-cz来替代git commit命令。否则,你需要按照下面指引安装依赖,让你的项目变为对 Commitizen 友好的。

使项目对 Commitizen 友好

通过 npm 安装

npm install --save-dev commitizen

初始化适配器

npx commitizen init cz-conventional-changelog --save-dev --save-exact

提交代码

# 暂存修改的代码
git add .

# 提交代码,该命令替代 git commit
npx git-cz

# 重新提交(使用上次输入的 commit 消息,这在提交失败后再次提交时特别有用)
npx git-cz --retry

参考Commit message 和 Change log 编写指南

Prettier - 美化代码格式

Prettier 是一个代码格式化程序(处理缩进、换行、空格等),它解析代码成抽象语法树(AST)并根据自定义格式重新输出代码,保证代码逻辑不变的前提下代码格式统一。它支持众多常见语言,例如 js/jsx/ts/tsx/json/css/scss/vue/yaml 等。

格式化指定文件

通过 npm 安装

npm install --save-dev prettier

执行下面命令后,prettier 格式化指定文件,并写回原文件(指定--write参数)。

npx prettier --write "src/**/*.js"

格式化本次 git 提交的文件

通过 npm 安装依赖

npm install --save husky lint-staged

package.json中添加如下配置,之后执行git commit前会对本次提交的文件进行格式化,并添加到本次提交内容中。也可以直接执行npx lint-staged格式化本次待提交文件。

  "husky": {
    "hooks": {
      "pre-commit": "lint-staged"
    }
  },
  "lint-staged": {
    "src/**/*.{js,jsx,ts,tsx,json,css,scss,md}": [
      "prettier --write",
      "git add"
    ]
  }

创建 .prettierrc 配置文件进行自定义。

ESLint - 检查 JS 代码质量

ESLint 是一个可插拔的 JS 和 JSX 检查工具。

检查指定文件

通过 npm 安装

npm install --save-dev eslint

执行下面命令后,eslint 会读取项目下的配置文件,然后对输入文件进行检查,并输出检查结果。

npx eslint "src/**/*.js"

检查本次 git 提交的文件

通过 npm 安装依赖

npm install --save-dev husky lint-staged

package.json中添加如下配置,之后执行git commit前 eslint 会对本次提交文件进行检查,如果检查存在问题(即 shell 指令返回非 0)则终止本次提交。

  "lint-staged": {
    "src/**/*.{js,jsx}": "eslint"
  },
  "husky": {
    "hooks": {
      "pre-commit": "lint-staged"
    }
  }

创建 .eslintrc 配置文件进行自定义,如果不知道如何配置,可执行eslint --init,然后根据提示做出选择,eslint 会自动生成一份配置文件。

Stylelint- 检查 CSS 代码质量

Stylelint 是一个强大的现代 CSS 检测器,可以让你在样式表中遵循一致的约定和避免错误。

通过 npm 安装

npm install --save-dev stylelint

使用 CLI 检测样式文件

npx stylelint "src/**/*.css"

结合 husky 使用,在提交代码前执行检查

  "husky": {
    "hooks": {
      "pre-commit": "stylelint src/**/*.css"
    }
  }

结合 husky 和 lint-staged 一起使用,检查本次提交中修改的文件

  "lint-staged": {
    "src/**/*.css": "stylelint"
  },
  "husky": {
    "hooks": {
      "pre-commit": "lint-staged"
    }
  }

创建 .stylelintrc 配置文件进行自定义。

预设配置

参考

node-blog 3.1 开发前的项目配置

最后

暂时先到这里,后续根据实际使用情况和工具变化再进行更新,如有问题,欢迎指正。