原生javaScript完成Ajax请求

Posted web_study

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了原生javaScript完成Ajax请求相关的知识,希望对你有一定的参考价值。

使用原生javascript完成Ajax请求,首先应该创建一个对象XMLHttprequest,考虑到兼容低版本IE浏览器,使用ActiveXObject对象,代码入下:

var request;
if(windoe.XMLHtprequest){
  request=new XMLHttprequest();
}else{
  request = new ActiveXObject();
}
function success(text) {
    var textarea = document.getElementById(‘test-ie-response-text‘);
    textarea.value = text;
}

function fail(code) {
    var textarea = document.getElementById(‘test-ie-response-text‘);
    textarea.value = ‘Error code: ‘ + code;
}

var request = new ActiveXObject(‘Microsoft.XMLHTTP‘); // 新建Microsoft.XMLHTTP对象

request.onreadystatechange = function () { // 状态发生变化时,函数被回调
    if (request.readyState === 4) { // 成功完成
        // 判断响应结果:
        if (request.status === 200) {
            // 成功,通过responseText拿到响应的文本:
            return success(request.responseText);
        } else {
            // 失败,根据响应码判断失败原因:
            return fail(request.status);
        }
    } else {
        // HTTP请求还在继续...
    }
}

// 发送请求:
request.open(‘GET‘, ‘/api/categories‘);
request.send();

alert(‘请求已发送,请等待响应...‘);

 

以上是关于原生javaScript完成Ajax请求的主要内容,如果未能解决你的问题,请参考以下文章

ajax简介+原生ajax代码

原生 JS Ajax,GET和POST 请求实例代码

Googlebot是否真的不等待AJAX 请求完成?

原生AJAX请求实例教程

原生JavaScript+ajax

JavaScript原生封装ajax请求和Jquery中的ajax请求