插入`··`更漂亮/更漂亮

Posted

技术标签:

【中文标题】插入`··`更漂亮/更漂亮【英文标题】:Insert `··` prettier/prettier 【发布时间】:2020-11-21 13:18:32 【问题描述】:

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

这是更漂亮的格式:

保存后,文件更改为:

这也是 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"]

【问题讨论】:

【参考方案1】:

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

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) 
  // ...

这是一个口味问题,但我认为这更容易阅读。

【讨论】:

为什么投反对票?问题是“解决方案是什么?”一种解决方案是使用加法运算符和/或加法赋值运算符而不是模板字符串。【参考方案2】:

未完全配置 ESlint 和 Prettier 可能会导致无数问题。为避免所有这些都遵循How to use Prettier with ESLint and TypeScript in VSCode 中提到的步骤,还要删除 ESlint、Prettier 和 VScod 的 setting.json 配置文件中可能覆盖其他规则的任何额外设置。

重要提示:基于here 的答案:卸载 prettier-eslint 扩展。

【讨论】:

你至少节省了我的 45 分钟:) 谢谢。

以上是关于插入`··`更漂亮/更漂亮的主要内容,如果未能解决你的问题,请参考以下文章

vs 代码更漂亮 - 在 @Input() 装饰器之后添加新行

如何禁用 eslint 上的错误(更漂亮/更漂亮)?

解析错误:由“<!DOCTYPE html>”引起的意外令牌更漂亮/更漂亮

更漂亮 + eslint 换行符

vscode 更漂亮的设置

Tslint/eslint vs 更漂亮