javascript 实现Ajax 资源请求

XMLHttpRequest


var xmlhttp = new XMLHttpRequest();
        xmlhttp.open("POST", "http://127.0.0.1:6767/api/v1/login", true);
        xmlhttp.send();
        xmlhttp.onreadystatechange = function () {
            if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
                console.log(xmlhttp)
                console.log(xmlhttp.response)
            }
        }

封装:

function ajax(options){
            var xmlhttp = new XMLHttpRequest();
            if(options.dataType == 'POST'){
                var sendUrl = options.url;
                var params = options.params;
                xmlhttp.open(options.dataType,sendUrl, true);
                xmlhttp.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
                if(typeof params != 'string'){
                    var paramsString = new String();
                    var paramsKeys = Object.keys(params);
                    paramsKeys.forEach((item,key)=>{
                        paramsString += item +'='+ params[item] + (key!=(paramsKeys.length-1)?'&':'')
                    })
                    params = paramsString;
                }
                xmlhttp.send(params)
            }
            if(options.dataType == 'GET'){
                var sendUrl = options.url + options.params;
                xmlhttp.open(options.dataType, sendUrl, true);
                xmlhttp.send(null)
            }
            xmlhttp.onreadystatechange = function() {
                if (xmlhttp.readyState==4 && xmlhttp.status==200){
                    console.log(xmlhttp.response)
                }
                
            }
        }

        ajax({
            url:'http://127.0.0.1:6767/api/v1/login',
            dataType:"POST",
            params:{'name':'admin'},
            success: function(res){  // 请求成功的回调函数
                console.log(JSON.parse(res)); 
            },
            error: function(error) {}  // 请求失败的回调函数
        })

JSONP:

var script = document.createElement("script");
        script.type = "text/javascript";
        script.src = "http://127.0.0.1:6767/api/v1/jsonp?callback=succersCallback";
        document.body.appendChild(script);
function succersCallback(data){
    console.log(data)
    console.log('执行')
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值