A router for Vanilla Single Page Application.
$ npm install @coheia/simple-router
Import the SimpleRouter class and its related types as follow:
import SimpleRouter from "@coheia/simple-router";
import SimpleRouter, { defineRenderMethod } from "@coheia/simple-router";
// The following imports are not provided by SimpleRouter:
import NotFound from "../pages/404/404"; // Component for page NotFound
import Home from "../pages/Home/Home"; // Component for page Home
import Contact from "../pages/Contact/Contact"; // Component for page Contact
import Blog from "../pages/Blog/Blog"; // Component for page Blog
import Article from "../pages/Blog/Article"; // Component for page Article
import type { Page } from "./Page"; // The type of the component
import { render } from "./render"; // SPA Render Method
// Step 1: Define the render method for the SPA
const renderMethod = defineRenderMethod<Page>(async (route) => {
const page = route.component();
render(await page.render(), "#router");
});
// Step 2: Create an instance of SimpleRouter
const router = new SimpleRouter<Page>(renderMethod, new NotFound());
// Step 3: Add routes to the router
router.addRoute("/", () => new Home());
router.addRoute("/contact", () => new Contact());
router.addRoute("/blog", () => new Blog());
router.addRoute("/blog/[slug]", (params) => new Article(params));
// Step 4: Start the router
router.start();
Your contributions are always welcome! Submit a pull request with your changes or create an issue to discuss anything.
This package is licensed under the MIT License.