路径上的 Eslint 导入/无无关依赖项错误

Eri*_*Lee 7 reactjs eslint graphql apollo-client eslintrc

我正在使用 Eslint 设置构建一个 React 应用程序。在我的应用程序中,我使用 GraphQL @apollo/client 依赖项。

当我尝试做的时候import { setContext } from '@apollo/client/link/context'

我收到一个 eslint 错误

'@apollo/client/link/context' should be listed in the project's dependencies. Run 'npm i -S @apollo/client/link/context' to add it  import/no-extraneous-dependencies
Run Code Online (Sandbox Code Playgroud)

我的 package.json 中确实有“@apollo/client”依赖项。根据 Apollo 文档,从 '@apollo/client/link/context' 导入是获取 'setContext' 的正确方法。

似乎import/no-extreaneous-dependencies无法识别“@apollo/client”的嵌套路径。

当我设置"import/no-extraneous-dependencies": 0.eslintrc.js 规则时,它会正常工作。但为了获得正确的解决方案,我假设我可能需要使用 .eslintrc.js 规则设置一些内容,而不是仅仅关闭 eslint 检查。

在这种情况下,我应该在 .eslintrc.js 中为我的规则编写哪些其他设置才能正确解决问题?

我的 package.json:

{
  "name": "my-app",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "@apollo/client": "^3.3.19",
    "@auth0/auth0-react": "^1.4.0",
    "@testing-library/jest-dom": "^5.11.4",
    "@testing-library/react": "^11.1.0",
    "@testing-library/user-event": "^12.1.10",
    "eslint": "^7.26.0",
    "eslint-config-airbnb": "^18.2.1",
    "eslint-plugin-import": "^2.22.1",
    "eslint-plugin-jsx-a11y": "^6.4.1",
    "eslint-plugin-react": "^7.23.2",
    "eslint-plugin-react-hooks": "^4.2.0",
    "graphql": "^15.5.0",
    "react": "^17.0.2",
    "react-big-calendar": "^0.33.3",
    "react-dom": "^17.0.2",
    "react-router-dom": "^5.2.0",
    "react-scripts": "4.0.3",
    "web-vitals": "^1.0.1"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject"
  },
  "eslintConfig": {
    "extends": [
      "react-app",
      "react-app/jest"
    ]
  },
  "browserslist": {
    "production": [
      ">0.2%",
      "not dead",
      "not op_mini all"
    ],
    "development": [
      "last 1 chrome version",
      "last 1 firefox version",
      "last 1 safari version"
    ]
  },
  "devDependencies": {}
}
Run Code Online (Sandbox Code Playgroud)

和我的 .eslintrc.js 文件:

module.exports = {
  env: {
    browser: true,
    es2021: true,
  },
  extends: [
    'plugin:react/recommended',
    'airbnb',
  ],
  parserOptions: {
    ecmaFeatures: {
      jsx: true,
    },
    ecmaVersion: 12,
    sourceType: 'module',
  },
  plugins: [
    'react',
  ],
  rules: {
    'no-console': 1,
    'react/prop-types': 0,
    'no-underscore-dangle': ['error', { allow: ['__raw'] }],
  },
  overrides: [
    {
      files: ['**/*.test.jsx'],
      env: { jest: true },
    },
  ],
};

Run Code Online (Sandbox Code Playgroud)

Tre*_*nis 6

我遇到了与问题 67587146rxjs/operators中所示的相同问题。解决方案是添加核心模块设置的路径。这个解决方案不是很好,但比禁用规则要好。.eslintrc.js

settings: {
  'import/core-modules': ['@apollo/client/link/context']
}
Run Code Online (Sandbox Code Playgroud)

  • 该规则应该能够解析嵌套包。此答案可以提供解决方案,直到此问题得到解决并且您可以升级。 (2认同)