Skip to content

acrool/acrool-react-router-hash

Acrool React Router Hash

Acrool React Router Hash Logo

Hash Route + History Route Additional based for React Router v7

NPM npm npm

npm downloads npm

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

Features

  • 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

Install

yarn add @acrool/react-router-hash

Usage

JSX Mode

import {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>;
};

Object Mode

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>;
};

Hook Mode

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/>},
            ],
        },
    ]);
};

Navigate & Hooks

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:

Play react-editext-example

License

MIT © Acrool & Imagine

About

Hash Route + History Route Additional based for React Route v6

Topics

Resources

License

Code of conduct

Contributing

Security policy

Stars

Watchers

Forks

Contributors