前提
Reactでwebアプリを作成しています。
React Routerを使用して、ページ遷移を実装しています。リロードせずにページの遷移をしたいです。
発生している問題・エラーメッセージ
親パス?が異なるページ間を移動する際はリロードせずにページ遷移してくれるのですが、同じ場合はブラウザのURLバーは変更されるにもかかわらずページ遷移してくれません。
例.
http://localhost:3001/individuals/1111111111 において、React RouterのLink要素使ってhttp://localhost:3001/individuals/1000010025 へのリンクを作って踏んでも、ブラウザのURLバーは"localhost:3001/individuals/1000010025"になるものの、ページ遷移はしてくれません。
一方で、http://localhost:3001/individuals/1111111111 からhttp://localhost:3001/treatments/1 のような親パス?が別のところに飛ぶリンクは他の場所で数個実装していて、問題なく動作しています。
該当のソースコード
App.tsx
typescript
1... 2<Router> 3 <Route path="/individuals/*" element={<Individuals />} /> 4</Router> 5...
Individuals.tsx
... <Routes> <Route path="/" element={<AllIndividuals />} /> <Route path="/:individualId" element={<ShowIndividual />} /> <Route path="/new" element={<NewIndividual />} /> </Routes> ...
IndividualShow.tsx
typescript
1import Link from '@mui/material/Link'; 2import { Link as RouterLink } from 'react-router-dom'; 3 4(中略) 5<Link component={RouterLink} to={`/individuals/${individual.id}`}> 6 <div> 7 リンク 8 </div> 9</Link> 10(中略)
試したこと
MUIを使わなくしたり、divのテキストの中身を変えてもやはり変化はありません。
また、リンクを<Link component={RouterLink} to='/individuals/2451191230'>と静的なものにしてもやはり動作せず。
意図的にindividualsをindividual(存在しないパス)にして<Link component={RouterLink} to='/individual/2451191230'>とすると遷移先を描画してくれました。
補足情報(FW/ツールのバージョンなど)
React: 18.1.0
react-router:6.3.0

回答1件
あなたの回答
tips
プレビュー