@syy11cn/config-router v1.0.5
Config Router 是什么? :thinking:
Config Router :wave: 是一个配合 React Router v5.x 使用的路由管理工具。 在 React Router 的基础上,提供 路由集中配置、路由渲染以及路由守卫 功能。
如果你曾使用过 Vue Router,你将很容易就能上手使用 Config Router。当然,本项目不如 Vue Router 那样成熟。:joy:
功能 :tada:
- :heavy_check_mark: 通过声明类似 Vue Router 中
routes数组的方式 配置路由。 - :heavy_check_mark: 通过
import一个RouterView组件的方式 渲染路由 :eyes:。 - :heavy_check_mark: 渲染页面前,支持自定义 路由守卫。
- :o: 敬请期待……
使用方法 :book:
你可以将这个包用于 react-jsx 或 react-tsx 项目中。在下面的使用方法中,将以 vite + react + typescript 搭建的项目为例。
添加 React Router 依赖
yarn add -s react-router-dom
yarn add -D @types/react-router-dom或使用
npm.npm i -s react-router-dom npm i -D @types/react-router-dom
添加 Config Router 依赖
添加完 React Router 依赖后,你可以将 config-router 添加到项目中。
yarn add -s @syy11cn/config-router或使用
npm.npm i -s @syy11cn/config-router
添加配置文件
在 src/routes 文件夹中创建一个配置文件(以 config.ts 文件为例)。
以下是配置样例。
// 首先引入 `routeType` 类型定义
import { routeType } from '@syy11cn/config-router';
// 引入需要用到的组件
import Index from '../views/Index';
import Portal from '../views/Portal';
import Test from '../views/Test';
import Error from '../views/Error';
// 路由配置
const routes: Array<routeType> = [
{
path: '/home',
component: Index,
routes: [
{
path: '/home/test',
component: Portal,
},
{
path: '/home',
component: Test,
},
],
},
{
path: '/404',
component: Error,
},
{
path: '/',
component: Portal,
},
];
export default routes;如上所示,路由配置是一个由 routeType 元素组成的数组。
routeType 的定义如下:
import * as React from 'react';
interface routeType {
path: string;
component: React.ComponentType<any>;
exact?: boolean;
routes?: Array<routeType> | undefined;
}
export default routeType;其中 routes 字段的值是一个新的 routeType 数组。
配置文件编写提示
- 在
routeType数组中,根路由应当永远处于数组的最后一位。 exact: true与routes字段不可兼得。path和component是必填项;exact和routes是可选项。
使用 RouterView 组件
在 main.tsx 中, 给 <App> 组件的外层添加 <Router> 组件。
import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import { BrowserRouter as Router } from 'react-router-dom';
ReactDOM.render(
<React.StrictMode>
<Router>
<App></App>
</Router>
</React.StrictMode>,
document.getElementById('root')
);接下来在 App.tsx 中, 使用 RouterView 组件。
import { FunctionComponent } from 'react';
import { Layout } from 'antd';
import { RouterView } from '@syy11cn/config-router';
import routes from './routes/config';
import './App.css';
const { Header, Content, Footer } = Layout;
interface AppProps {}
const App: FunctionComponent<AppProps> = () => {
return (
<div align=center className="App">
<Header></Header>
<Content>
<RouterView
routes={routes}
onEnter={function (to, next): void {
console.log('onEnter');
next();
}}
></RouterView>
</Content>
<Footer></Footer>
</div>
);
};
export default App;RouterView 组件将在 <Content> 组件中渲染路由。渲染的路由组件将取代 RouterView 的位置。
嵌套路由
在配置的例子中,Index 组件包含嵌套路由。注意:无论你在任何地方使用 RouterView 组件,你都需要给它传入 routes 字段。
因此,在 src/views/Index.tsx 中,Index 组件应该接收一个 routes 属性。这个属性包含了 Index 组件下的子路由。
import { FunctionComponent } from 'react';
import { RouterView } from '../routes';
import { routeType } from '@syy11cn/config-router';
interface IndexProps {
routes: Array<routeType>;
props: any;
}
const Index: FunctionComponent<IndexProps> = ({ routes, props }) => {
console.log('Index View');
return (
<div align=center>
<h1>This is Index</h1>
<RouterView
routes={routes}
onEnter={(to, next) => {
if (to === '/home/test') {
next();
} else {
next('/404');
}
}}
></RouterView>
</div>
);
};
export default Index;路由守卫
向 onEnter 字段中传入一个函数,这个函数将在路由渲染之前被执行。
传入的函数应该接受两个参数,分别是 to 和 next。
to是一个string类型的数据,用于表明用户将要前往哪个路由。next是一个Function类型的数据,如果你向next函数中传入一个字符串,那么它将帮你重定向到对应的路径;如果你直接调用next函数,则会放通用户当前的路由。
示例代码同上:
import { FunctionComponent } from 'react';
import { RouterView } from '../routes';
import { routeType } from '@syy11cn/config-router';
interface IndexProps {
routes: Array<routeType>;
props: any;
}
const Index: FunctionComponent<IndexProps> = ({ routes, props }) => {
console.log('Index View');
return (
<div align=center>
<h1>This is Index</h1>
<RouterView
routes={routes}
onEnter={(to, next) => {
if (to === '/home/test') {
next();
} else {
next('/404');
}
}}
></RouterView>
</div>
);
};
export default Index;在这种情况下,当用户想要访问 /home/test 时,对应的路由和组件将被渲染。而当用户想要访问 /home 或其他以 /home 开头的域名时,其将被重定向到 404 页面。
贡献 :computer:
欢迎贡献!你可以 fork 这个仓库,然后提 PR。
在使用中有任何问题,也可以 点击这里发布一个 issue,我收到消息后会尽快尽力处理。
关于 :raised_hands:
开源协议
Copyright (c) 2021, Yiyang Sun