插入“··”漂亮/漂亮

时间:2020-07-31 17:02:19

标签: visual-studio-code eslint prettier react-tsx

我有一个同时安装了漂亮和eslint的项目。问题是,当我保存文件时,eslint会自动更改文件的格式,并且似乎有些规则与漂亮的规则冲突。解决办法是什么?

这是更漂亮的格式: enter image description here

保存后,文件更改为: enter image description here

这也是eslintrc文件

{
  "parser": "@typescript-eslint/parser",
  "extends": [
    "plugin:react/recommended",
    "plugin:@typescript-eslint/recommended",
    "plugin:prettier/recommended",
    "prettier/@typescript-eslint"
  ],
  "rules": {
    "@typescript-eslint/explicit-function-return-type": "off",
    "@typescript-eslint/no-explicit-any": "off",
    "@typescript-eslint/ban-ts-ignore": "off",
    "@typescript-eslint/interface-name-prefix": "off",
    "@typescript-eslint/no-unused-vars": ["warn", { "argsIgnorePattern": "^_" }]
  },
  "overrides": [
    {
      "files": ["**/*.tsx"],
      "rules": {
        "react/prop-types": "off"
      }
    }
  ],
  "settings": {
    "react": {
      "version": "detect"
    }
  },
  "ignorePatterns": ["coverage/", "node_modules/", "src/serviceWorker.ts"]
}

2 个答案:

答案 0 :(得分:1)

未完全配置ESlint和Prettier可能会导致许多问题。为避免它们全部遵循How to use Prettier with ESLint and TypeScript in VSCode中提到的步骤,还应删除配置文件中ESlint,Prettier和VScod的setting.json的所有其他设置,这些设置可能会覆盖其他规则。

重要提示:根据答案here 卸载 prettier-eslint 扩展。

答案 1 :(得分:0)

一种解决方法可能是使用加法运算符(+)连接字符串,而不使用模板字符串:

try {
  const response = await api.get(
    API_BOARDS +
      boardSearchParam.boardId +
      `?assignees=${boardSearchParam.assigneeIds.toString()}/`
  );
} catch (err) {
  // ...
}

根据您的ESLint规则,您可能会收到一条错误消息,提示您应使用模板字符串而不是加法运算符。在这种情况下,您可以创建一个变量并使用加法赋值运算符(+=

try {
  let url = API_BOARDS + boardSearchParam.boardId;
  url += `?assignees=${boardSearchParam.assigneeIds.toString()}/`

  const response = await api.get(url);
} catch (err) {
  // ...
}

这是一个品味问题,但是我认为它读起来更好一些。