Hash Route + History Route Additional based for React Router v7
with react-router-dom version 7.x
^4.0.0 support react-router-dom >=7.0.0, react >=18.0.0 <20.0.0
^3.2.0 support react-router-dom 6.x, react >=18.0.0 <20.0.0
- With react-router-dom version 7.x
- In CSR, it is easy to implement the light box routing function
- Supports both JSX mode and object mode route definitions
- Modified and enhanced HashRouter function by react-router-dom, supports path params
- Extract the shared optical box to the router to separate dependencies
- With @acrool/react-modal to support persistent lightbox
yarn add @acrool/react-router-hashimport {BrowserRouter as Router, Route, Routes} from 'react-router-dom';
import {HashRoute, HashRoutes, useHashParams, useHashPathname} from '@acrool/react-router-hash';
const MainRouter = () => {
return <Router>
{/* Base pathname */}
<Routes>
<Route path="/" element={<Dashboard/>}/>
<Route path="*" element={<NotFound/>}/>
</Routes>
{/* Hash pathname */}
<HashRoutes>
<HashRoute path="login" element={<Login/>}/>
<HashRoute path="control/*" element={<EditLayout/>}>
<HashRoute path="editAccount/:id" element={<EditAccount/>}/>
<HashRoute path="editPassword" element={<EditPassword/>}/>
</HashRoute>
</HashRoutes>
</Router>;
};import {BrowserRouter as Router, Route, Routes} from 'react-router-dom';
import {HashRoutes} from '@acrool/react-router-hash';
const MainRouter = () => {
return <Router>
{/* Base pathname */}
<Routes>
<Route path="/" element={<Dashboard/>}/>
<Route path="*" element={<NotFound/>}/>
</Routes>
{/* Hash pathname — object mode */}
<HashRoutes routes={[
{path: 'login', element: <Login/>},
{
path: 'control/*',
element: <EditLayout/>,
children: [
{path: 'editAccount/:id', element: <EditAccount/>},
{path: 'editPassword', element: <EditPassword/>},
],
},
]}/>
</Router>;
};import {useHashRoutes} from '@acrool/react-router-hash';
const HashRouter = () => {
return useHashRoutes([
{path: 'login', element: <Login/>},
{
path: 'control/*',
element: <EditLayout/>,
children: [
{path: 'editAccount/:id', element: <EditAccount/>},
{path: 'editPassword', element: <EditPassword/>},
],
},
]);
};import {useNavigate} from 'react-router-dom';
import {useHashParams, useHashPathname} from '@acrool/react-router-hash';
const Dashboard = () => {
const navigate = useNavigate();
return <div>
<h2>Dashboard</h2>
<button type="button" onClick={() => navigate({hash: '/control/editAccount/1'})}>
EditAccount HashModal
</button>
<button type="button" onClick={() => navigate({hash: '/control/editPassword'})}>
EditPassword HashModal
</button>
</div>;
};
const EditAccount = () => {
const {id} = useHashParams<{id: string}>();
const navigate = useNavigate();
const pathname = useHashPathname();
return <>
<p>hash pathname: {pathname}</p>
<p>useHashParams id: {id}</p>
<button type="button" onClick={() => navigate({hash: undefined})}>Close HashModal</button>
</>;
};There is also a example that you can play with it: