Eslint + Prettier + VScode 规范代码风格(针对react+typescript)

近期有做 eslint 统一代码风格的事情,结合自己的沉淀和网上的解决方案,分享一套 针对 react + typescripteslint 配置方案,配置完成后可以检测代码,统一代码风格,VScode 保存自动格式化代码。

1、使用 Eslint 来规范 typescript 代码
安装依赖:

npm i -D eslint @typescript-eslint/parser @typescript-eslint/eslint-plugin

这三个依赖分别是:
eslint: ESLint 的核心代码
@typescript-eslint/parser:ESLint 的解析器,用于解析typescript ,从而检查和规范 Typescript代码
@typescript-eslint/eslint-plugin:这是一个 ESLint 插件,包含了各类定义好的检测 Typescript 代码的规范

在项目根目录下新建 .eslintrc.js 文件,代码暂时如下

module.exports = {
    env:{                          //指定代码的运行环境
        browser: true,
        node: true,
    },
    parser:  '@typescript-eslint/parser', //定义ESLint的解析器
    extends: ['plugin:@typescript-eslint/recommended'],//定义文件继承的子规范
    plugins: ['@typescript-eslint'],//定义了该eslint文件所依赖的插件                        
}

由于是 typescript 项目,所以 parser 需要配置成 @typescript-eslint/parser 才能正确检测代码。
其次 env 是配置环境,比如 console 只有在 browser 环境才存在,如果不配置的话可能会标红报错。

2、使用 Eslint 规范 React 代码
安装依赖:

npm i -D eslint-plugin-react

接着在 .eslintrc.js 中配置如下:

module.exports = {
    env:{                         
        browser: true,
        node: true,
    },
    parser:  '@typescript-eslint/parser',
    extends: [
    'plugin:react/recommended'  
    'plugin:@typescript-eslint/recommended'
    ],                              //使用推荐的React代码检测规范
    plugins: ['@typescript-eslint'],
    settings: {             //自动发现React的版本,从而进行规范react代码
        "react": {
            "pragma": "React",
            "version": "detect"
        }
    }, 
    parserOptions: {        //指定ESLint可以解析JSX语法
        "ecmaVersion": 2019,
        "sourceType": 'module',
        "ecmaFeatures":{
            jsx:true
        }
    },
    rules: {
        // 可以定义react 编码规则
    }
}

3、结合 Prettier 规范代码
安装依赖

npm i -D prettier eslint-config-prettier eslint-plugin-prettier

Prettier:Prettier插件的核心代码
eslint-config-prettier:解决 ESLint 中的样式规范和 Prettier 中样式规范的冲突,以 Prettier的样式规范为准
eslint-plugin-prettier:将 Prettier 作为 ESLint 规范来使用

根目录下创建 .prettierrc.js 文件,配置如下:

module.exports =  {
  "eslintIntegration": true,
  "printWidth": 150, // 每行代码长度(默认80)
  "tabWidth": 2, // 每个tab相当于多少个空格(默认2)
  "useTabs": false, // 是否使用tab进行缩进(默认false)
  "singleQuote": true, // 使用单引号(默认false)
  "semi": true, // 声明结尾使用分号(默认true)
  "trailingComma": "none", // 多行使用拖尾逗号(默认none)
  "bracketSpacing": true, // 对象字面量的大括号间使用空格(默认true)
  "jsxBracketSameLine": false, // 多行JSX中的>放置在最后一行的结尾,而不是另起一行(默认false)
  "arrowParens": "avoid" // 只有一个参数的箭头函数的参数是否带圆括号(默认avoid)
};

修改 .eslintrc.js 文件,引入 Prettier

module.exports = {
  env: {
    browser: true,
    node: true
  },
  parser: '@typescript-eslint/parser',
  extends: [
    'plugin:react/recommended',
    'plugin:@typescript-eslint/recommended',
    'prettier/@typescript-eslint',
    'plugin:prettier/recommended',
  ], //使用推荐的React代码检测规范
  plugins: ['@typescript-eslint'],
  settings: {
    //自动发现React的版本,从而进行规范react代码
    react: {
      pragma: 'React',
      version: 'detect'
    }
  },
  parserOptions: {
    //指定ESLint可以解析JSX语法
    ecmaVersion: 2019,
    sourceType: 'module',
    ecmaFeatures: {
      jsx: true
    }
  },
  rules: {
    'no-console': process.env.NODE_ENV === 'production' ? 'error' : 'off',
    'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off',
    semi: ['error', 'always'],
    eqeqeq: 'off',
    'linebreak-style': ['error', 'unix'],
    'no-useless-call': 'off',
    'space-before-function-paren': ['error', { anonymous: 'always', named: 'never', asyncArrow: 'always' }]
  }
};

4、 结合VScode
安装 VScode 插件 ESlint Prettier
然后配置 setting.json

"editor.tabSize": 2,
"editor.detectIndentation": false, // 全部统一成2空格缩进
"eslint.enable": true,  //是否开启vscode的eslint
"editor.codeActionsOnSave": {
    "source.fixAll.eslint": true
},
"eslint.options": {    //指定vscode的eslint所处理的文件的后缀
"extensions": [
    ".js",
  ".jsx",
    ".ts",
    ".tsx"
]
},
"eslint.validate": [     //确定校验准则
    "javascript",
    "javascriptreact",
    "html",
    "typescript",
    "typescriptreact"
],

至此,重新启动 VScode 就能看到效果,command + s 保存文件的时候回自动补全代码。

5、兼容老项目
针对老项目中有 .js.jsx 混合的文件,可以在根目录下新建 .eslintignore 配置如下:

**/*.js
**/*.jsx

这样下来, eslint 就会忽略所有的 .js.jsx 文件的校验。

6、使用 husky lint-staged 来控制 git 提交之前的校验
其中 husky 可以配置git 提供的钩子,比如 pre-commit pre-push 等。
lint-stagedgit add . 之后“暂存” 状态的文件,也就是本次 git 提交的文件
安装依赖

npm i -D husky lint-staged

package.json 文件配置如下:

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

这样配置好之后,在提交 git 的时候,修改的文件如果没有修复 eslint 的报错,就会无法提交。

坑:"*.{js,jsx,ts,tsx}": "eslint" 这里的配置{js,jsx,ts,tsx} 逗号后面不能空格,否则匹配不到文件,逗号后面不能空格,否则匹配不到文件,逗号后面不能空格,否则匹配不到文件!!!

特殊办法: 可以在后面加 --no-verify 跳过验证

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,716评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,558评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,431评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,127评论 0 209
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,511评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,692评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,915评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,664评论 0 202
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,412评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,616评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,105评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,424评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,098评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,096评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,869评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,748评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,641评论 2 271

推荐阅读更多精彩内容