首页 > 解决方案 > ESLint 排序导入多行换行

问题描述

我想使用sort-imports eslint 规则对导入语句进行排序,但是当我进行多行导入时,它会将每个导入的东西都分成一个新行。

我的问题是我想让导入多行,但在指定宽度后换行。

//My use case
import { a, b, c, z, x, h } from x;

//How is linting
import {
  a
  , b
  , c
  , h
  , x
  , z
} from x;

//How I want to works
import {
  a, b, c
  , h, x, z
} from x;

在这种情况下,只有 3 个导入,我不介意导入的东西是否只在一行中,但我的问题是当我有很多东西时(比如我要导入 20 个 ramda 函数)并且我不想破坏每个导入的功能进入一个新的行。

这是我目前的 eslint + 更漂亮的配置:

.eslintrc.json

{
  "root": true,
  "extends": [
    "plugin:vue/essential",
    "plugin:prettier/recommended",
    "eslint:recommended"
  ],
  "parserOptions": {
    "ecmaVersion": 2019,
    "sourceType": "module"
  },
  "env": {
    "es6": true
  },
  "rules": {
    "indent": ["error", 2],
    "arrow-parens": ["error", "always"],
    "sort-imports": [
      "error",
      {
        "ignoreDeclarationSort": true
      }
    ],
    "comma-style": ["error", "first"],
    "comma-spacing" :["error", {
      "after": true
    }]
  }
}

.prettierrc.json

{
  "arrowParens": "always",
  "bracketSpacing": true,
  "htmlWhitespaceSensitivity": "css",
  "insertPragma": false,
  "jsxBracketSameLine": false,
  "jsxSingleQuote": false,
  "printWidth": 80,
  "proseWrap": "preserve",
  "quoteProps": "as-needed",
  "requirePragma": true,
  "semi": true,
  "singleQuote": true,
  "tabWidth": 2,
  "trailingComma": "es5",
  "useTabs": false,
  "vueIndentScriptAndStyle": false
}

标签: javascripteslintprettier

解决方案


你应该加载plugin:prettier/recommended之后eslint:recommended停止 eslint 重新格式化更漂亮的东西


推荐阅读