Typescript eslint - Brakujące rozszerzenie / rozszerzenie „ts” rozszerzenia pliku

33

Mam prostą aplikację Node / Express wykonaną za pomocą maszynopisu. I eslint daje mi błąd

Missing file extension "ts" for "./lib/env" import/extensions

Oto mój plik .eslintrc

    {
  "extends": [
    "airbnb",
    "plugin:@typescript-eslint/recommended",
    "prettier",
    "prettier/react",
    "plugin:import/errors",
    "plugin:import/warnings",
    "plugin:import/typescript"
  ],
  "parser": "@typescript-eslint/parser",
  "plugins": ["@typescript-eslint", "prettier", "import"],
  "settings": {
    "import/extensions": [".js", ".jsx", ".ts", ".tsx"],
    "import/parsers": {
      "@typescript-eslint/parser": [".ts", ".tsx"]
    },
    "import/resolver": {
      "typescript": {
        "directory": "./tsconfig.json"
      },
      "node": {
        "extensions": [".js", ".jsx", ".ts", ".tsx"]
      }
    }
  },
  "rules": {
    "@typescript-eslint/indent": [2, 2],
    "no-console": "off",
    "import/no-unresolved": [2, { "commonjs": true, "amd": true }],
    "import/named": 2,
    "import/namespace": 2,
    "import/default": 2,
    "import/export": 2
  }
}

Zainstalowałem eslint-plugin-impor i eslint-import-resolver-maszynopis. I nie mogę zrozumieć, dlaczego dostałem ten błąd.

Nolat
źródło

Odpowiedzi:

69

Dodaj następujący kod do rules:

"rules": {
   "import/extensions": [
      "error",
      "ignorePackages",
      {
        "js": "never",
        "jsx": "never",
        "ts": "never",
        "tsx": "never"
      }
   ]
}

airbnbESLint config prowadzi problem.

superoryco
źródło
9
Pracował! Dzięki. (inni czytelnicy: upewnij się, że umieściłeś go w „regułach”, a nie „ustawieniach” ...)
Venryx