原生ajax 请求

本文介绍如何使用const request对象的AJAX方法进行HTTP请求,包括GET和POST请求,同时处理了参数格式化、token认证及错误处理。核心内容涉及HTTP请求的异步处理和数据格式设置。
摘要由CSDN通过智能技术生成
const request = {
    ajax(options){
        options = options || {};
        options.type = (options.type || "GET").toUpperCase();
        options.dataType = options.dataType || 'json';
        options.async = options.async === undefined?true:options.async;
        options.format = options.format === undefined?true:options.format;//
        options.contentType = options.contentType === undefined?true:options.contentType;
        var params = options.format?this.formatParams(options.data):options.data;
        if(window.XMLHttpRequest){
            var xhr = new XMLHttpRequest()
        }else{
            var xhr = new ActiveXObject('Microsoft.XMLHTTP')
        }
        xhr.onreadystatechange = function(){
            if(xhr.readyState == 4){
             var status = xhr.status;
                if(status >=200 && status< 300){
                    options.success && options.success(xhr.responseText,xhr.responseXML)
                }else{
                    if(options.fail){
                        options.fail(status)
                    }
                }
            }
        }
        //连接和发送
        let _header = options._token &&  this.getCookie(options._token);//获取token
        options.contentType && xhr.setRequestHeader("Content-Type","application/x-wwww-form-urlencoded");
        options._token && xhr.setRequestHeader(options._token,_header);
        xhr.setRequestHeader("Cache-Control","no-cache");
        if(options.type == "GET"){
            xhr.open("GET",`${options.url}?${params}`,options.async);
            xhr.send(null)
        }else if(options.type === "POST"){
            xhr.open("POST",options.url,options.async);
            xhr.send(params)
        }
    },
    formatParams(data){
        let arr = [];
        for (const name in data) {
            if (object.hasOwnProperty(name)) {
                arr.push(`${encodeURIComponent(name)}=${encodeURIComponent(data[name])}`)
            }
        }
        return arr.join('&')
    },
    getCookie(c_name){
        if(document.cookie.length>0){
            let c_start = document.cookie.indexOf(`${c_name}=`)
            if(c_start != -1){
                c_start = c_start + c_name.length+1;
                let c_end = document.cookie.indexOf(":",c_start);
                if(c_end == -1){
                    c_end = document.cookie.length
                    return document.cookie.substring(c_start,c_end);
                }
            }
            return ""
        }
    },
   
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值