A smart way to eslint stylelint and git hooks for front end
felint 是一个同步前端代码检查规则的工具。
felint 为你的项目做以下两件事:
- 初始化 eslint/stylelint 配置文件,无论是 react 项目、vue 项目、es5 还是 es6 都提供了针对性的配置方案
- 安装 eslint/stylelint 及其依赖到当前项目的 node_modules 里
npm install -g felint
在项目的根目录,执行
felint init
felint
初始化完成后你的项目中将会产生如下目录和文件:
|_.felintrc // 第一次被执行 felint init 后会在项目根目录生成这个文件,里面包含了使用哪个配置方案等信息
|_.felint // felint-config文件夹
|_.eslintrc.json // eslint 规则文件,用于检测js代码(使用的是官方推荐的配置)
|_.eslintignore // eslint ignore配置文件
|_.stylelintrc.js // stylelint 规则文件,用于检测css代码(使用的是官方推荐的配置)
|_.stylelintignore // stylelint ignore配置文件
同时,当你在运行 git commit
时自动检测待提交的文件是否符合相应规范。如无法通过校验,将无法提交。
当你需要再一个项目的不同目录使用不同的代码规范时,我们可以通过 .felintrc
自定义校验规则:
{
"plan": {
"./app": "node",
"./client": "vue"
}
}
此时在 ./app
目录生成 node 相关的校验规则,在 ./client
目录会生成 vue 相关的校验规则。
将这些新增的代码提交到 git 仓库
felint-config
:里面包含了代码校验规则的配置信息,默认为:felint-config.felintrc
:类似于.babelrc
文件,放在项目根目录用于配置felint-config
的git仓库地址,和项目的代码规范方案。eslint
:JavaScript
代码校验工具,详细文档点这里stylelint
:CSS
代码校验工具,详细文档点这里
felint init -p planname -f force
planname:
用于指定初始化规则方案
force:
是否强制覆盖已有的规则
执行 felint init
命令后,felint将从 .felintrc
中读取 felint-config
git仓库地址 或 使用默认地址https://github.com/youzan/felint-config(如没有.felintrc文件)下载所需的默认的配置文件并保存在项目的 .felint
文件夹下。
当配置文件下载完成后,felint
将自动执行配置文件内部的初始化脚本文件,并生成最终规则文件。
关于规则方案声明请参见felint-config介绍
该命令会下载 eslint
和 stylelint
需要的依赖,并写入到 package.json
中。
felint dep
该命令会先将最新的 felint-config
下载到本地,然后依据 .felintrc
里配置的 plan
规则生成对应的规则文件。
felint rule -f force
force:
是否强制覆盖已有的规则
felint config-url
输出 felint config
配置的仓库地址。
.felintrc用于配置felint-config
的git仓库地址、对默认规则进行一定程度的自定义覆盖以及记录该项目所使用的代码规则方案。
e.g.
{
gitHookUrl // 用于指定使用的felint-config仓库地址
plan // 用于指定当前项目所使用的规则方案,比如es5/es6/vue/react等
}
如果你不想使用我们默认的felint-config校验,你可以fork出来修改为自己的felint-config(修改方法参考 felint-config 的 readme ),然后在 .felintrc
文件的 gitHookUrl
字段中手动配置你自己的 felint-config
仓库地址。
然后重新执行一次 felint init
即可。
该字段用于记录执行felint init -p value
时所使用的规范方案(如果不指定则为default)。
felint将在你执行felint init
命令的时候自动检查更新。当发现有新版本felint时,将在命令行提醒你是否需要更新。
本项目基于 MIT协议,请自由地享受和参与开源。