English | 简体中文
路由一直是前端开发的重要组成部分,主流框架都有官方或社区的提供的路由支持,比如 vue-router 和 react-router,但它们都与框架深度绑定而无法共用。oh-router 将核心功能与框架解绑,以此在不同的框架之间提供一致的 API 接口。
特性:
- 开箱即用的路由中间件功能
- 与 react-router 使用体验一致的
路由匹配
和hooks
路由匹配
和hooks
直接基于 react-router v6
- 支持 Vue 和 React
安装依赖
$ npm install --save oh-router oh-router-react
下面是一个结合 React 最基本的使用案例:在 StackBlitz 中打开
import { Router } from 'oh-router'
import { RouterView, Link } from 'oh-router-react'
import ReactDOM from 'react-dom/client'
const router = new Router({
routes: [
{
path: '/',
element: () => (
<div>
<div>Home</div>
<Link to="/about">to About</Link>
</div>
),
},
{
path: '/about',
element: () => (
<div>
<div>About</div>
<Link to="/">to Home</Link>
</div>
),
},
],
})
ReactDOM.createRoot(document.getElementById('root')!).render(
<RouterView router={router} />
)
安装依赖
$ npm install --save oh-router oh-router-vue
下面是一个结合 Vue 最基本的使用案例:在 StackBlitz 中打开
<div id="app">
<router-view />
</div>
<script>
import { Router } from 'oh-router'
import { installForVue } from 'oh-router-vue'
import { createApp } from 'vue'
const router = new Router({
routes: [
{
path: '/',
element: {
template: `<div>
<div>Home</div>
<router-link to="/about">to About</router-link>
</div`,
},
},
{
path: '/about',
element: {
template: `<div>
<div>About</div>
<router-link to="/">to Home</router-link>
</div`,
},
},
],
})
const app = createApp({})
app.use(installForVue(router))
app.mount('#app')
</script>
import Router from 'oh-router'
const app = document.querySelector<HTMLDivElement>('#app')!
const routes = [
{
path: '/',
element: `<div>Home</div>
<div>
<button onclick="to('/libs')">libs</button>
<button onclick="to('/languages')">languages</button>
</div>`,
children: [
{
path: '/libs',
element: `<ul>
<li onclick="to('/libs/react')"><button>React</button></li>
<li onclick="to('/libs/vue')"><button>Vue</button></li>
<ul/>`,
},
{
path: '/libs/:name',
element: `Lib: `,
name: 'lib-detail',
},
{
path: '/languages',
element: `<ul><li>Java</li><li>Go</li><ul/>`,
},
],
},
{
path: '*',
element: '404',
},
]
const router = new Router({ routes })
.addLocationListener((location) => {
let content = location.matched.map(({ route }) => route.element).join('\n')
const lastRoute = location.matched[location.matched.length - 1]
if (lastRoute.route.name === 'lib-detail') {
content += lastRoute.params.name
}
app.innerHTML = content
})
.start()
window.to = function to(path: string) {
router.navigate(path)
}