首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何配置lint-staged以运行eslint和更漂亮的脚本

如何配置lint-staged以运行eslint和更漂亮的脚本
EN

Stack Overflow用户
提问于 2021-08-04 12:01:56
回答 1查看 671关注 0票数 0

我有这样的设置:

代码语言:javascript
复制
// package.json

...
  "scripts": {
    ...
    "lint": "eslint --fix {src,test}/**/*.{js,ts,jsx,tsx} --no-error-on-unmatched-pattern",
    "style": "prettier --write {src,test}/**/* ./*.{json,*.json} !package-lock.json -u --no-error-on-unmatched-pattern",
...
  "lint-staged": {
    "lint-staged": {
      "{src,test}/**/*.{js,ts,jsx,tsx}": [
        "npm run lint",
        "npm run style"
      ],
      "!**/*.{js,ts,jsx,tsx}": "npm run style"
    },
  }
...

问题是,无论glob匹配哪个文件,prettier都会运行,prettier也会在所有文件上加倍运行,并将所有文件重写两次。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-08-04 12:01:56

在使用lint-staged时,不能使用双glob表达式,这会导致冲突。

代码语言:javascript
复制
// package.json

...
  "scripts": {
    ...
    "lint": "eslint --fix {src,test}/**/*.{js,ts,jsx,tsx} --no-error-on-unmatched-pattern",
    "style": "prettier --write {src,test}/**/* ./*.{json,*.json} !package-lock.json -u --no-error-on-unmatched-pattern",
...
  "lint-staged": {
    "lint-staged": {
      "{src,test}/**/*.{js,ts,jsx,tsx}": [
        "eslint --fix",
        "prettier --write -u"
      ],
      "!**/*.{js,ts,jsx,tsx}": "prettier --write -u"
    },
  }
...

在运行lint-staged时只需使用prettier --write -ueslint --fix,不要运行您的自定义脚本,否则globs会相互冲突。相反,只需直接在与lint-staged匹配的glob上运行eslint和更漂亮即可。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68650902

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档