【问题标题】:Property 'exact' does not exist on type类型上不存在属性“确切”
【发布时间】:2021-12-20 07:06:11
【问题描述】:

我正在尝试在我的 React 应用程序中使用 react-router-dom,并且我使用的是打字稿而不是 javascript。这里的问题是我无法在我的组件中导入 Route 并使其工作。我已经安装了@types/react-router-dom,但由于某种原因它仍然没有按预期工作。

这是一个试图使用react-router-dom的组件

import {BrowserRouter as Router, Route} from "react-router-dom";

const App = () => {
    return (
        <div>
            <Router>
                <div>
                    <Route path="/" exact/>
                </div>
            </Router>
        </div>
    )
}

export default App;

这是我得到的错误

TypeScript error in /Users/veselinkontic/Projects/givellet/frontend/src/components/index.tsx(9,37):
Type '{ path: string; exact: true; }' is not assignable to type 'IntrinsicAttributes & (PathRouteProps | LayoutRouteProps | IndexRouteProps)'.
  Property 'exact' does not exist on type 'IntrinsicAttributes & (PathRouteProps | LayoutRouteProps | IndexRouteProps)'.  TS2322

     7 |             <Router>
     8 |                 <div>
  >  9 |                     <Route path="/" exact/>
       |                                     ^
    10 |                 </div>
    11 |             </Router>
    12 |         </div>

这是我的 package.json 文件,您可以在其中看到所有内容。

  "name": "frontend",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "@testing-library/jest-dom": "^5.11.4",
    "@testing-library/react": "^11.1.0",
    "@testing-library/user-event": "^12.1.10",
    "@types/jest": "^26.0.15",
    "@types/node": "^12.0.0",
    "@types/react": "^17.0.0",
    "@types/react-dom": "^17.0.0",
    "@types/react-router-dom": "^5.3.2",
    "react": "^17.0.2",
    "react-dom": "^17.0.2",
    "react-router-dom": "^6.0.1",
    "react-scripts": "4.0.3",
    "typescript": "^4.1.2",
    "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"
    ]
  }
}

【问题讨论】:

    标签: reactjs typescript react-router react-router-dom


    【解决方案1】:

    react router v6 不再支持exact

    // 旧 - v5 &lt;Route exact path="/" component={Home} /&gt;

    // 新 - v6 &lt;Route path="/" element={&lt;Home /&gt;} /&gt;

    如他们的文档中所述:

    您不再需要在 &lt;Route path="/"&gt; 上使用精确的道具。 这是因为默认情况下所有路径都完全匹配。如果你 想要匹配更多的 URL,因为您有子路由使用尾随 * 作为 在&lt;Route path="users/*"&gt;.

    您可以参考这个迁移指南:https://reactrouter.com/docs/en/v6/upgrading/v5

    【讨论】:

    • 感谢您指出这一点。此外,在没有更多时间线在 v5 和 v6 之间迁移的情况下,看到如此剧烈的重大变化令人沮丧。对于某些人来说,实际上是数百个文件。
    【解决方案2】:

    我不知道这种情况是否经常发生在你身上。

    但是你有:

    "dependencies": {
      ...
      "@types/react-router-dom": "^5.3.2",
      ...
      "react-router-dom": "^6.0.1",
      ...
    },
    

    也许问题是你的 react-router-dom 的版本和类型不一样,导致兼容性问题。此库尚未更新。我刚开始的一个项目也发生了同样的事情。

    要解决此问题,您可以将 react-router-dom 的版本降级到 v5 并使用该语法,或者等待类型更新并使用最新版本。请记住,v6 中有重要更改,当您有大量代码时更新可能会很复杂。

    同样,前面的答案是正确的,react-router的新v6中不存在exact

    在这里您可以看到类型的当前版本: https://www.npmjs.com/package/@types/react-router-dom

    【讨论】:

    • 不是类型库没有更新;从 v6 开始,react-router-dom 包含自己的类型声明,并且不再需要 @types 包。
    【解决方案3】:

    我也遇到过同样的问题,新的 React-Router 不支持 exact 关键字。您可以简单地将其从 中删除,它会正常工作。

    除了component,你还必须使用element并将元素标签传递给它。

    【讨论】:

      猜你喜欢
      • 2017-06-06
      • 1970-01-01
      • 2021-01-09
      • 2021-07-10
      • 2021-06-16
      • 2019-06-26
      • 1970-01-01
      • 2017-07-22
      相关资源
      最近更新 更多