zoukankan      html  css  js  c++  java
  • fetch封装

      对fetch方法做简单的封装,完成需要统一处理的功能:antd - Table参数映射;取消短时间内的重复请求;options.params参数拼接到url;options.body转换json;headers.Authorization请求头认证赋值;请求异常统一处理;增删改成功提示

    import {message} from 'antd';
    import _ from '_';
    import {cookieUtil} from './util';
    
    const REQUEST_RECORD = {},
        DEFAULT_REQUEST_INTERVAL = 1000,
        DEFAULT_FETCH_OPTIONS = {
            method: 'GET',
            mode: 'cors',
            headers: {},
        },
        SHOW_MSG_METHOD = {
            POST: true,
            PUT: true,
            DELETE: true,
        };
    
    /**
     * Requests a URL, returning a promise.
     *
     * @param  {string} url       The URL we want to request
     * @param  {object} [options] The options we want to pass to "fetch"
     * @return {object}           An object containing either "data" or "err"
     */
    export default function request(url, options = {}) {
        options = handleTableParams(options);
        if (!isRepeatedRequest(url, options)) return null;
        const fetchUrl = generateUrl(url, options);
        const fetchOptions = generateOptions(options);
        return fetch(fetchUrl, fetchOptions)
            .then(checkStatus)
            .then(parseJSON)
            .then(data => {
                if (options['showMsg'] !== false && SHOW_MSG_METHOD[options.method]) {
                    message.success(getMessage(options.method), 2);
                }
                return data;
            })
            .catch(() => {
                return null;
            });
    }
    
    function handleTableParams(options) {
        const params = (options.params = options.params || {});
        if (params.pagination) {
            params.current = options.pagination.current;
            params.pageSize = options.pagination.pageSize;
            delete params.pagination;
        }
        const filters = params.filters;
        if (filters) {
            Object.assign(params, filters);
            delete params.filters;
        }
        if (params.sorter) {
            const field = params.sorter.field,
                order = params.sorter.order;
            if (field && order) params[order] = field;
            delete params.sorter;
        }
        return options;
    }
    
    function isRepeatedRequest(url, options) {
        let record = REQUEST_RECORD[url],
            now = new Date().getTime();
    
        if (record && _.isEqual(record.options, options) && now - record.lastTime < DEFAULT_REQUEST_INTERVAL) return false;
        REQUEST_RECORD[url] = {
            options: _.assign({}, options),
            lastTime: now,
        };
        return true;
    }
    
    function generateUrl(url, options) {
        const params = options.params;
        if (typeof params === 'object') {
            let paramArray = [];
            Object.keys(params).forEach(key => {
                if (paramArray.length === 0) {
                    paramArray.push('?');
                } else {
                    paramArray.push('&');
                }
                paramArray.push(key);
                paramArray.push('=');
                paramArray.push(params[key]);
            });
            if (paramArray.length !== 0) {
                return url + paramArray.join('');
            }
        }
        return url;
    }
    
    function generateOptions(options) {
        const fetchOptions = _.assign({}, DEFAULT_FETCH_OPTIONS),
            method = options.method,
            data = options.body;
        options.method = options.method ? options.method.toUpperCase() : 'GET';
        if (method) fetchOptions.method = method;
        if (data && Object.prototype.toString.call(data) === '[object Object]') {
            fetchOptions.body = JSON.stringify(data);
            fetchOptions.headers['Content-Type'] = 'application/json';
        }
        const token = cookieUtil.getCookie('token');
        if (token) fetchOptions.headers.Authorization = token;
        return fetchOptions;
    }
    
    function checkStatus(response) {
        if (response.status >= 200 && response.status < 300) {
            return response;
        } else {
            var error = new Error(response.statusText);
            response.json().then(data => {
                message.error(data.message || data, 2);
                console.error(data);
            });
            throw error;
        }
    }
    
    function parseJSON(response) {
        return response.json();
    }
    
    function getMessage(method) {
        let sub = '';
        switch (method) {
            case 'POST':
                sub = '新增成功';
                break;
            case 'PUT':
                sub = '修改成功';
                break;
            case 'DELETE':
                sub = '删除成功';
                break;
            default:
                break;
        }
        return sub;
    }
  • 相关阅读:
    SqlLite的使用
    asp.net批量上传图片带进度条显示
    对于GridView控件的RowDataBount事件的错误理解
    关于SQL中时间对比
    关于使用触发器时使用@@identity的问题
    关于Treeview控件如何给每个节点加js脚本的方法
    /etc/init.d/functions详解
    如何解决安装DreamWeaver8 时候提示“无法将数值写入键/SOFTWARE/classes/.shtml”
    [请教]关于超大数据量网站的数据搜索和分页的实现方法
    svchost.exe[900]中发生未处理的win32异常
  • 原文地址:https://www.cnblogs.com/zengyuanjun/p/14472364.html
Copyright © 2011-2022 走看看