插入`··` prettier/prettier
Insert `··` prettier/prettier
我有一个项目同时安装了 prettier 和 eslint。问题是,当我保存文件时,eslint 会自动更改文件的格式,并且似乎某些规则与 prettier 冲突。解决方法是什么?
这是更漂亮的格式:
保存后,文件变为:
这也是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"]
}
一种解决方法是使用加法运算符 (+
) 连接字符串,而不是使用模板字符串:
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) {
// ...
}
这是一个品味问题,但我认为这更好读。
没有完全配置 ESlint 和 Prettier 会导致无数问题。为了避免所有这些都遵循 How to use Prettier with ESLint and TypeScript in VSCode 中提到的步骤,还要删除 ESlint、Prettier 和 setting.json 配置文件中可能覆盖其他规则的 VScod 的任何额外设置。
重要提示:根据回答 :卸载 prettier-eslint
扩展。
.prettierrc
{
"printWidth": 160
}
我有一个项目同时安装了 prettier 和 eslint。问题是,当我保存文件时,eslint 会自动更改文件的格式,并且似乎某些规则与 prettier 冲突。解决方法是什么?
这是更漂亮的格式:
保存后,文件变为:
这也是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"]
}
一种解决方法是使用加法运算符 (+
) 连接字符串,而不是使用模板字符串:
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) {
// ...
}
这是一个品味问题,但我认为这更好读。
没有完全配置 ESlint 和 Prettier 会导致无数问题。为了避免所有这些都遵循 How to use Prettier with ESLint and TypeScript in VSCode 中提到的步骤,还要删除 ESlint、Prettier 和 setting.json 配置文件中可能覆盖其他规则的 VScod 的任何额外设置。
重要提示:根据回答 prettier-eslint
扩展。
.prettierrc
{
"printWidth": 160
}