类型上不存在属性“exact”

问题描述 投票:0回答:7

我正在尝试在我的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
7个回答
296
投票

react router v6 不再支持

exact

// 旧版 - v5

<Route exact path="/" component={Home} />

// 新 - v6

<Route path="/" element={<Home />} />

如其文档中所述:

您不再需要在

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

您可以参考此迁移指南:https://reactrouter.com/en/main/upgrading/v5


14
投票

对于 React Router v6,我将 Routes 和 Route 添加到导入中。

示例:

import { BrowserRouter, Route, Routes  } from 'react-router-dom';
import  Home  from "./pages/Home";
import  NewRoom  from "./pages/NewRoom";
    
function App() {
  return (
  <BrowserRouter>
      <Routes>
      <Route path="/"  element={<Home />}/>
      <Route path="/rooms/new" element={<NewRoom />}/>
      </Routes>
  </BrowserRouter>
  );
}
    
export default App;

5
投票

我也遇到过同样的问题,新的 React-Router 不支持

exact
关键字。您只需将其从 中移除即可正常工作。

此外,您必须使用

component
并将元素标签传递到其中,而不是
element


1
投票

只需将

exact
替换为
end

<NavLink exact>
重命名为
<NavLink end>
https://reactrouter.com/en/v6.3.0/upgrading/v5#rename-navlink-exact-to-navlink-end


0
投票

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

但是你有:

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

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

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

同样,之前的答案都是正确的,

exact
react-router
的新v6中不存在。

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


0
投票

“react-router-dom”中的语法已更改

“@types/react-router-dom”:“^5.3.2”,=====>

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

"react-router-dom": "^6.0.1",============>

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

请更新语法

<BrowserRouter>
  <Header/>

  <Routes>
    <Route path="/" Component={Home} />
    <Route path="/about" Component={About} />
  </Routes>
</BrowserRouter>

====================================================== ==============

或使用“路线”中的“元素”

<BrowserRouter>
  <Header/>

  <Routes>
    <Route path="/" element={<Home/>} />
    <Route path="/about" element={<About />} />
  </Routes>
</BrowserRouter>

-3
投票

对我有用的是重新安装软件包

npm install react-router-dom

© www.soinside.com 2019 - 2024. All rights reserved.