使用redux,react在纯函数中触发react-router-dom页面跳转

栏目: 服务器 · 发布时间: 6年前

内容简介:文章有错误和不合理的地方欢迎小伙伴轻拍这就是困扰我的问题对fetch()进行封装,并对请求的返回数据做拦截,当捕捉到错误的时候,判断错误的状态码,404时让页面跳转到404页面,当时401时跳转到登录页面,500调整到500页面。

文章有错误和不合理的地方欢迎小伙伴轻拍

痛点

这就是困扰我的问题

对fetch()进行封装,并对请求的返回数据做拦截,当捕捉到错误的时候,判断错误的状态码,404时让页面跳转到404页面,当时401时跳转到登录页面,500调整到500页面。

react-router ^4并没有暴露出来history对象,这让非组件内页面跳转变的困难。

问题的解决

定义store

function navTo(state = "/", action) {
    switch (action.type) {
        case 'NAV_TO':
            return action.path;
        default:
            return state
    }
}

let store = createStore(combineReducers({navTo}));
export default store;

fetch()状态拦截代码

import store from "../../redux/store";
fetch(builUrl(url, params), requestInit)
        .then(data => {
            return data.json()
        }).catch(e => {
            const status = e.name;
            if (status === 401) {
                store.dispatch({type: 'NAV_TO', path: '/login'});
                return;
            }
            if (status === 403) {
                store.dispatch({type: 'NAV_TO', path: '/exception/403'});
                return;
            }
            if (status <= 504 && status >= 500) {
                store.dispatch({type: 'NAV_TO', path: '/exception/500'});
                return;
            }
            if (status >= 404 && status < 422) {
                store.dispatch({type: 'NAV_TO', path: '/exception/404'});
                return;
            }
        })

app.js实现对store的订阅,并跳转页面

import React, {Component} from 'react';
import store from './app/common/redux/store.js'
import {withRouter} from "react-router-dom";
@withRouter
class App extends Component {

    constructor(props) {
        super(props);
        store.subscribe(() => {
            this.props.history.push(store.getState().navTo);
        });
    }

    render() {
        return (
            <div>
                {this.props.children}
            </div>
        );
    }
}

export default App;

当fetch()拦截到错误就可以进行页面调整了

如果对redux有疑问,可以看我另一篇文章

https://segmentfault.com/a/11...

这就是在函数中通过订阅的方式来实现页面跳转,easy easy !!!

小伙伴可以举一反三运用到更多的地方去!!

:+1::+1::+1::+1::+1:如果能帮助到小伙伴的话欢迎点个赞:+1::+1::+1::+1::+1:

:+1::+1::+1::+1::+1:如果能帮助到小伙伴的话欢迎点个赞:+1::+1::+1::+1::+1:


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

正当法律程序简史

正当法律程序简史

(美)约翰·V.奥尔特 / 杨明成、陈霜玲 / 商务印书馆 / 2006-8 / 14.00元

本书的主题——正当法律程序,是英美法的核心概念,它使诸如法治、经济自由、个人自治以及免于政府专断行为的侵害等价值观念具体化,因而是法学领域一个永恒的主题,数百年以来一直是法学家、法官及律师关注的重点。本书以极为简洁、精确的语言总结了五百年法律发展的恢弘历史,为人们描述了正当法律程序观念发展演变的清晰轨迹。而沿着这条轨迹,人们可以准确地了解正当法律程序这一重要概念所包含的广泛的问题。 作为一本......一起来看看 《正当法律程序简史》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具