router5

Flexible and powerful universal routing solution

Github stars Tracking Chart

Router5

npm version
License: MIT
Build Status Join the chat at https://gitter.im/router5/router5 styled with prettier

Official website: router5.js.org

router5 is a framework and view library agnostic router.

  • view / state separation: router5 processes routing instructions and outputs state updates.
  • universal: works client-side and server-side
  • simple: define your routes, start to listen to route changes
  • flexible: you have control over transitions and what happens on transitions
import createRouter from 'router5'
import browserPlugin from 'router5-plugin-browser'

const routes = [
    { name: 'home', path: '/' },
    { name: 'profile', path: '/profile' }
]

const router = createRouter(routes)

router.usePlugin(browserPlugin())

router.start()

With React (new context API)

import React from 'react'
import ReactDOM from 'react-dom'
import { RouteProvider, Route } from 'react-router5'

function App({ route }) {
    if (!route) {
        return null
    }

    if (route.name === 'home') {
        return <h1>Home</h1>
    }

    if (route.name === 'profile') {
        return <h1>Profile</h1>
    }
}

ReactDOM.render(
    <RouteProvider router={router}>
        <Route>{({ route }) => <App route={route} />}</Route>
    </RouteProvider>,
    document.getElementById('root')
)

With observables

Your router instance is compatible with most observable libraries.

import { from } from 'rxjs/observable/from'

from(router).map(({ route }) => {
    /* happy routing */
})

Examples

Docs

Main metrics

Overview
Name With Owneralibaba/ARouter
Primary LanguageJava
Program languageJavaScript (Language Count: 4)
Platform
License:Apache License 2.0
所有者活动
Created At2016-12-14 01:27:49
Pushed At2023-09-11 06:07:41
Last Commit At2021-06-17 16:33:36
Release Count20
Last Release Name1.5.2 (Posted on 2021-06-22 13:15:24)
First Release Name1.0.1 (Posted on 2017-01-04 17:52:12)
用户参与
Stargazers Count14.5k
Watchers Count365
Fork Count2.6k
Commits Count301
Has Issues Enabled
Issues Count909
Issue Open Count123
Pull Requests Count79
Pull Requests Open Count11
Pull Requests Close Count64
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private