質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

1回答

1599閲覧

親パスが同じページ同士でリンクする際にReact Routerが機能しない

Dearg

総合スコア22

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2022/06/04 15:04

編集2022/06/13 17:49

前提

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

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hoshi-takanori

2022/06/04 15:34

ソースが部分的でよく分かりません。Route タグはどうなって (id をどうやって受け取って) ますか?
Dearg

2022/06/05 07:06

ソースコードをいくつかと、試したことを追記させていただきました。 idは<ShowIndividual>の中で const { individualId } = useParams(); で受け取っています。その先はバックエンドがRailsのAPIモードでして、useEffectでindividual(個体)ごとのデータを取得して表示するようになっています。
hoshi-takanori

2022/06/07 14:54

ShowIndividual の中で useEffect の第 2 引数に individualId を渡せば、individualId が変わった際に API を呼び直して表示を更新できると思いますが…。(URL が変わっても、API の結果を取得するまでは古い情報が表示されたままになると思うので、そこもなんとかする必要がありそう。)
Dearg

2022/06/13 08:47 編集

おっしゃる通りでした...useEffectの第2引数にindividualIdを入れることで解決しました。 APIの結果を取得する間はロード中のスケルトンが出るようにしていたと思います。ありがとうございます...!
guest

回答1

0

自己解決

useEffectの引数にIndividualIdを入れることでAPIを再度叩いてくれて表示を変えることができました。
ありがとうございます。

投稿2022/06/13 08:49

Dearg

総合スコア22

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問