1. ホーム
  2. node.js

[解決済み] パースエラーです。ファイル '.../tsconfig.json' を読み込むことができません.eslint

2022-06-23 05:14:21

質問

エラー Parsing error: Cannot read file '.../tsconfig.json'.eslint は、すべての .ts ファイル内の src フォルダーにある index.ts .

コンフィグの設定方法が全くわかりません。問題は、赤い線が表示され、ファイルが赤くなるだけです。しかし、すべてがうまくコンパイルされ、実行されます。Nodeプロジェクト全体はfirebase CLIを使用して作成されました。

tsconfig.json というファイルを作成します。

{
  "compilerOptions": {
    "module": "commonjs",
    "noImplicitReturns": true,
    "noUnusedLocals": true,
    "outDir": "lib",
    "sourceMap": true,
    "strict": true,
    "target": "es2017"
  },
  "compileOnSave": true,
  "include": [
    "src"
  ]
}

.eslintrc.js ファイルを作成します。

module.exports = {
  env: {
    browser: true,
    es6: true,
    node: true,
  },
  extends: [
    "plugin:import/errors",
    "plugin:import/warnings",
    "plugin:import/typescript",
  ],
  parser: "@typescript-eslint/parser",
  parserOptions: {
    project: "tsconfig.json",
    sourceType: "module",
  },
  plugins: [
    "@typescript-eslint",
    "import",
  ],
  rules: {
    "@typescript-eslint/adjacent-overload-signatures": "error",
    "@typescript-eslint/no-empty-function": "error",
    "@typescript-eslint/no-empty-interface": "warn",
    "@typescript-eslint/no-floating-promises": "error",
    "@typescript-eslint/no-namespace": "error",
    "@typescript-eslint/no-unnecessary-type-assertion": "error",
    "@typescript-eslint/prefer-for-of": "warn",
    "@typescript-eslint/triple-slash-reference": "error",
    "@typescript-eslint/unified-signatures": "warn",
    "comma-dangle": "warn",
    "constructor-super": "error",
    eqeqeq: ["warn", "always"],
    "import/no-deprecated": "warn",
    "import/no-extraneous-dependencies": "error",
    "import/no-unassigned-import": "warn",
    "no-cond-assign": "error",
    "no-duplicate-case": "error",
    "no-duplicate-imports": "error",
    "no-empty": [
      "error",
      {
        allowEmptyCatch: true,
      },
    ],
    "no-invalid-this": "error",
    "no-new-wrappers": "error",
    "no-param-reassign": "error",
    "no-redeclare": "error",
    "no-sequences": "error",
    "no-shadow": [
      "error",
      {
        hoist: "all",
      },
    ],
    "no-throw-literal": "error",
    "no-unsafe-finally": "error",
    "no-unused-labels": "error",
    "no-var": "warn",
    "no-void": "error",
    "prefer-const": "warn",
  },
  settings: {
    jsdoc: {
      tagNamePreference: {
        returns: "return",
      },
    },
  },
};

私はVScodeを再起動し、キャッシュをクリアし、そして無駄にすべてを試していました。パスのいくつかを変更する必要があると思いますが、設定ファイルを変更するのはあまり得意ではないので、誤ってプロジェクト全体を壊したくありません。

どのように解決するのですか?

デフォルトでは project の中にある parserOptions ) は、現在の作業ディレクトリからの相対パスで解決されます。もしあなたが eslint を含むフォルダーと異なる作業ディレクトリで tsconfig.json を含む別の作業ディレクトリにある場合、@typescript-eslint/parserはそのファイルを見つけることができません。

これを修正するために tsconfigRootDir __dirname という相対的なプロジェクト構成を解決するようになります。 .eslintrc.js :

module.exports = {
  // ...
  parserOptions: {
    project: "tsconfig.json",
    tsconfigRootDir: __dirname,
    sourceType: "module",
  },
  // ...
}


で何かトラブルがあった場合

/path/to/.eslintrc.js
  0:0  error  Parsing error: "parserOptions.project" has been set for @typescript-eslint/parser.
The file does not match your project config: .eslintrc.js.
The file must be included in at least one of the projects provided

見る この質問 .