ルートパラメータは、動的セグメントから解析された値です。
<Route path="/concerts/:city" element={<City />} />
この場合、:city
が動的セグメントです。その都市の解析された値は、useParams
から利用できます。
import { useParams } from "react-router";
function City() {
let { city } = useParams();
let data = useFakeDataLibrary(`/api/v2/cities/${city}`);
// ...
}
検索パラメータは、URLの?
の後の値です。これらはuseSearchParams
からアクセスでき、URLSearchParams
のインスタンスを返します。
function SearchResults() {
let [searchParams] = useSearchParams();
return (
<div>
<p>
You searched for <i>{searchParams.get("q")}</i>
</p>
<FakeSearchResults />
</div>
);
}
React Routerは、useLocation
でアクセスできる、いくつかの有用な情報を含むカスタムlocation
オブジェクトを作成します。
function useAnalytics() {
let location = useLocation();
useEffect(() => {
sendFakeAnalytics(location.pathname);
}, [location]);
}
function useScrollRestoration() {
let location = useLocation();
useEffect(() => {
fakeRestoreScroll(location.key);
}, [location]);
}