jquery-ajax封装

/** 请求
 * @Author: xuhong
 * @Date: 2020/6/19
 * @DESC: //TODO
 */


/**
 * 发送请求,处理请求失败
 *
 * request(url, method, data, callback)
 * request(url, method, callback)
 * request(url, callback)
 *
 * @param url
 * @param method 默认get
 * @param data
 * @param callback - 需要一个参数接收返回的数据
 */
function request(url, method='get', data, callback) {
    if (typeof data == 'function') {
        callback = data;
        data = '';
    }
    if (typeof method == 'function') {
        callback = method;
        method = 'get';
    }

    $.ajax({
        type: method,
        url: url,
        data: data,
        traditional: true, // 防止深度序列化,保证数据结构不乱(如数组)
        success(res) {
            if (res.code == 200) {
                !callback || callback(res.data);
            } else {
                alert(res.message);
            }
        },
        error(res) {
            console.log('请求失败,请稍后再试');
            window.location.open('error.html', '_self');
        }
    });
}

/**
 * 文件上传
 * @param url 地址
 * @param formData 表单数据,文件数据写入里面
 * @param callback 回调函数
 *
 * 例:
 *  const formData = new FormData();
 *  formData.append('file', file);
 */
function uploadFile(url, formData, callback) {
    $.ajax({
        url: url,
        type: 'post',
        data: formData,
        // 以下三个属性是为了防止ajax对数据的处理
        cache: false, // 禁止读取缓存中的结构
        contentType: false, // 数据编码格式不使用jquery的方式
        processData: false, // 默认情况下,前后端传递的数据都会自动转换成字符串,这里表示不对数据进行转换
        success(res) {
            if (res.code == 200) {
                !callback || callback(res.data);
            } else {
                alert(res.message);
            }
        },
        error(res) {
            console.log('请求失败,请稍后再试');
            window.location.open('error.html', '_self');
        }
    });
}

/**
 * 对象转地址参数
 * @param data  需要转换的对象
 */
function toParam(data) {
    let rel = '';
    for (let key in data) {
        rel += '&' + key + '=' + data[key];
    }
    return rel.replace(/^&/, '?');
}
/**
 * 地址参数转对象
 * @param data  地址参数
 */
function paramParse(data) {
    data = decodeURI(data);
    let rel = {};
    data = data.replace(/\?/, '');
    data.split('&').map(value => {
        let p = value.split('=');
        rel[p[0]] = p[1];
    });
    return rel;
}

 

posted @ 2020-07-20 11:52  Lanomw  阅读(187)  评论(0编辑  收藏  举报