最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - ESLint error: 'default' is restricted from being used as an exported name - Stack Overflow

programmeradmin4浏览0评论

I am getting this eslint error in index.js file:

'default' is restricted from being used as an exported name no-restricted-exports

page / index.js

export { default } from './test';

page / test.jsx

import React from 'react';

const Test = () => {
  return <div>Test</div>;
};
export default Test;

routes.js

import React from 'react';
import { Switch, Route } from 'react-router-dom';

const testPage = React.lazy(() => import('./page'));

function Routes() {
  return (
    <Switch>
      <Route path="/" exact ponent={testPage} />
    </Switch>
  );
}
export default Routes;

.eslintrc.json

{
  "env": {
    "browser": true,
    "es2021": true
  },
  "extends": ["plugin:react/remended", "airbnb"],
  "parserOptions": {
    "ecmaFeatures": {
      "jsx": true
    },
    "ecmaVersion": "latest",
    "sourceType": "module"
  },
  "plugins": ["react"],
  "rules": {
    "import/extensions": [
      "error",
      "ignorePackages",
      {
        "js": "never",
        "jsx": "never"
      }
    ],
    "react/jsx-filename-extension": [
      1,
      {
        "extensions": [".js", ".jsx"]
      }
    ]
  },
  "settings": {
    "import/extensions": [".js", ".jsx"],
    "import/resolver": {
      "node": {
        "extensions": [".js", ".jsx"]
      }
    }
  }
}

What would be the proper way to resolve it, without disabling that?

I am getting this eslint error in index.js file:

'default' is restricted from being used as an exported name no-restricted-exports

page / index.js

export { default } from './test';

page / test.jsx

import React from 'react';

const Test = () => {
  return <div>Test</div>;
};
export default Test;

routes.js

import React from 'react';
import { Switch, Route } from 'react-router-dom';

const testPage = React.lazy(() => import('./page'));

function Routes() {
  return (
    <Switch>
      <Route path="/" exact ponent={testPage} />
    </Switch>
  );
}
export default Routes;

.eslintrc.json

{
  "env": {
    "browser": true,
    "es2021": true
  },
  "extends": ["plugin:react/remended", "airbnb"],
  "parserOptions": {
    "ecmaFeatures": {
      "jsx": true
    },
    "ecmaVersion": "latest",
    "sourceType": "module"
  },
  "plugins": ["react"],
  "rules": {
    "import/extensions": [
      "error",
      "ignorePackages",
      {
        "js": "never",
        "jsx": "never"
      }
    ],
    "react/jsx-filename-extension": [
      1,
      {
        "extensions": [".js", ".jsx"]
      }
    ]
  },
  "settings": {
    "import/extensions": [".js", ".jsx"],
    "import/resolver": {
      "node": {
        "extensions": [".js", ".jsx"]
      }
    }
  }
}

What would be the proper way to resolve it, without disabling that?

Share Improve this question edited Oct 27, 2023 at 3:22 Rajiv 3,7722 gold badges17 silver badges32 bronze badges asked Mar 30, 2022 at 11:59 Zahra TavakoliZahra Tavakoli 1061 silver badge6 bronze badges
Add a ment  | 

3 Answers 3

Reset to default 4
export { default as Test } from './test';

if above one is used then you've to do named import instead of default import like this

import { Test } from './pathToTestFolder'

this is not wrong, but to still using the default import you've to export test by default. You can do this

page/index.js

import Test from './test'

export default Test

now you can use default import like this
routes.js

import Test from './pathToTestFolder'

or according to your route file

const testPage = React.lazy(() => import('./page'));

You cannot export default because it's a reserved keyword. You could replace the line with :

export { default as Test } from './test';

In situations where named and default export is conflicting with ESLint rules, you can use * export approach as follows:

export * from './test';
发布评论

评论列表(0)

  1. 暂无评论