当前位置: 首页 > 工具软件 > History.js > 使用案例 >

dva history.block 路由守卫、路由拦截 功能实现, 关键词: dva2.0 history.block react-router react-router-guards

华俊贤
2023-12-01
// 路由监听
export const RouterGuards = (history) => {
    // history.block 使用方法参考
    // https://stackoverflow.com/questions/65526447/react-router-v5-2-blocking-route-change-with-createbrowserhistory-and-history
    // history.block 从回调中返回 false 会阻止通过,返回 true 允许通过。
    history.block((location, action) => { // 路由拦截 路由守卫        
        const info = auth.getUserInfo()
        if (!info) { // 没登录/没有权限/路由权限校验
            console.warn('没有登录', location);
            checkLogin()
            return false
        } else { // 校验是否拥有该路由权限
            let hasRouterAuth = checkAuth(location, 'router')
            if (!hasRouterAuth) {
                console.warn('没有目标路由权限', location);
                return false
            } else {
                // console.warn('有目标路由权限', location);
                return true
            }
        }
    })
}

其中 RouterGuards 的入参 history 来自

// index.js
import dva from 'dva';
import 'antd/dist/antd.css';
import './permission'

// 1. Initialize
const app = dva()

// 3. Model
// app.model(require('./models/example').default);

// 4. Router
app.router(require('./router').default);

// 5. Start
app.start('#root');

// router.js
import React from 'react';
import dynamic from 'dva/dynamic'
import { Router, Route, Switch } from 'dva/router';
import { checkLogin, RouterGuards } from './permission'

import { ConfigProvider } from 'antd';
import zhCN from 'antd/es/locale/zh_CN';

// import { HashRouter as Router, Route } from 'react-router-dom'
import CacheRoute, { CacheSwitch } from 'react-router-cache-route'

import Welcome from 'widget/Layout/Welcome/WelcomeView'
function RouterConfig({ history, app }) {
    checkLogin() // 校验登录
    RouterGuards(history) // 监听路由
    
    const App = dynamic({
        app,
        models: () => [ import('./widget/Layout/App/AppMod') ],
        component: () => import('./widget/Layout/App/AppView')
    });
    const NotFound = dynamic({
        app,
        component: () => import('./pages/404')
    });
    const PageList = dynamic({ // 渲染页面
        app,
        models: () => [ import('./pages/PageList/PageListMod') ],
        component: () => import('./pages/PageList/PageList')
    })

    return (
        <ConfigProvider locale={zhCN}>
            <Router history={history}>
                <CacheSwitch>
                    <Route exact path="/login" component={Login} />
                    <Route path='/' component={() => (
                        <App history={history}>
                            <CacheSwitch>
                                <Route path="/" exact component={Welcome} />
                                <Route path="/PageList" exact component={PageList} />

                                <Route component={NotFound} />
                            </CacheSwitch>
                        </App>
                    )}></Route>
                    <Route component={NotFound} />
                </CacheSwitch>
            </Router>
        </ConfigProvider>
    );
}

export default RouterConfig;

其中 版本说明

	"dva": "2.4.1"
	"react-router": "4.3.1"
    "react-router-dom": "^4.1.2",
 类似资料: