我正在尝试在我的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"
]
}
}
react router v6 不再支持
exact
。
// 旧版 - v5
<Route exact path="/" component={Home} />
// 新 - v6
<Route path="/" element={<Home />} />
如其文档中所述:
您不再需要在
上使用精确的道具。 这是因为默认情况下所有路径都完全匹配。如果你 想要匹配更多的 URL,因为您的子路由使用尾随 * 作为 在<Route path="/">
。<Route path="users/*">
您可以参考此迁移指南:https://reactrouter.com/en/main/upgrading/v5
对于 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;
我也遇到过同样的问题,新的 React-Router 不支持
exact
关键字。您只需将其从 此外,您必须使用
component
并将元素标签传递到其中,而不是 element
。
只需将
exact
替换为 end
。
将
重命名为<NavLink exact>
。 https://reactrouter.com/en/v6.3.0/upgrading/v5#rename-navlink-exact-to-navlink-end<NavLink end>
我不知道这种情况是否一直发生在你身上。
但是你有:
"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
“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>
对我有用的是重新安装软件包
npm install react-router-dom