原生ajax调用,实例讲解使用原生JavaScript处理AJAX请求的方法

本文详细解析Ajax的工作原理,从创建XMLHttpRequest对象到处理服务器响应,展示了如何利用原生JavaScript实现AJAX请求。此外,还介绍了如何封装Ajax方法并提供一个实际操作示例,帮助开发者理解Ajax在提升用户体验和优化服务器负载中的作用。
摘要由CSDN通过智能技术生成

Ajax 是异步的JavaScript和XML的简称,是一种更新页面某部分的机制。它赋予了你从服务器获取数据后,更新页面某部分的权力,从而避免了刷新整个页面。另外,以此方式实现页面局部更新,不仅能有效地打造流畅的用户体验,而且减轻了服务器的负载。

下面是对一个基本的 Ajax 请求进行剖析:

var xhr = new XMLHttpRequest();

xhr.open('GET', 'send-ajax-data.php');

xhr.send(null);

在这里, 我们创建了一个能向服务器发出 HTTP 请求的类的实例。然后调用其 open 方法,其中第一个参数是 HTTP 请求方法,第二个参数是请求页面的 URL。最后,我们调用参数为 null 的 send 方法。假如使用 POST 请求方法(这里我们使用了 GET),那么 send 方法 的参数应该包含任何你想发送的数据。

下面是我们如何处理服务器的响应:

xhr.onreadystatechange = function(){

var DONE = 4; // readyState 4 代表已向服务器发送请求

var OK = 200; // status 200 代表服务器返回成功

if(xhr.readyState === DONE){

if(xhr.status === OK){

console.log(xhr.responseText); // 这是返回的文本

} else{

console.log("Error: "+ xhr.status); // 在此次请求中发生的错误

}

}

}

onreadystatechange 是异步的,那么这就意味着它将可在任何时候被调用。这种类型的函数被称为回调函数——一旦某些处理完成后,它就会被调用。在此案例中,这个处理发生在服务器。

示例

便捷的 Ajax 方法也是不少人依赖 jQuery 的原因,但实际上原生 JavaScript 的 Ajax api 也很强大,并且基本的使用在各个浏览器中的差异不大,因此完全可以自行封装一个 Ajax 对象,下面是封装好的 Ajax 对象:

// Ajax 方法

// 惰性载入创建 xhr 对象

function createXHR(){

if ( 'XMLHttpRequest' in window ){

createXHR = function(){

return new XMLHttpRequest();

};

} else if( 'ActiveXObject' in window ){

createXHR = function(){

return new ActiveXObject("Msxml2.XMLHTTP");

};

} else {

createXHR = function(){

throw new Error("Ajax is not supported by this browser");

};

}

return createXHR();

}

// Ajax 执行

function request(ajaxData){

var xhr = createXHR();

ajaxData.before && ajaxData.before();

// 通过事件来处理异步请求

xhr.onreadystatechange = function(){

if( xhr.readyState == 4 ){

if( xhr.status == 200 ){

if( ajaxData.dataType == 'json' ){

// 获取服务器返回的 json 对象

jsonStr = xhr.responseText;

json1 = eval('(' + jsonStr + ')'),

json2 = (new Function('return ' + jsonStr))();

ajaxData.callback(json2);

// ajaxData.callback(JSON.parse(xhr.responseText)); // 原生方法,IE6/7 不支持

} else

ajaxData.callback(xhr.responseText);

} else {

ajaxData.error && ajaxData.error(xhr.responseText);

}

}

};

// 设置请求参数

xhr.open(ajaxData.type, ajaxData.url);

if( ajaxData.noCache == true ) xhr.setRequestHeader('If-Modified-Since', '0');

if( ajaxData.data ){

xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');

xhr.send( ajaxData.data );

} else {

? ?

xhr.setRequestHeader('X-Requested-With', 'XMLHttpRequest');

xhr.send( null );

}

return xhr;

}

function post(ajaxData){

ajaxData.type = 'POST';

var _result = request(ajaxData);

return _result;

}

function get(ajaxData){

ajaxData.type = 'GET';

ajaxData.data = null;

var _result = request(ajaxData);

return _result;

}

下面给出一个使用例子:

index.html

原生 JavaScript 实现 Ajax

#content {text-align: center; font-family: 'lucida Grande', 'Microsoft Yahei'}

#content .btn_ctr {display: block; width: 120px; height: 30px; margin: 0 auto 20px; background: #53a7bb; color: #fff; font-weight: bold; font-size: 14px; line-height: 30px; text-decoration: none;

border-radius: 4px;

}

#test {width: 280px; height: 130px; margin: 0 auto; padding: 15px; background: #fff; border-radius: 4px; text-align: left; }

// Ajax 方法,这里不在重复列出

ajax.html

ajax

成功获取到这段文本

具体的效果可以浏览完整 Demo 。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值