概述
很多人跟我一样用习惯了jq封装好的$.ajax,但是面试时,原生ajax是很多面试官喜欢问的问题,今天再查资料,打算好好整理一下自己理解的原生ajax。
首先,jq的ajax:一般我常用的参数就是这些,不过可以配置的参数不止这些
$.ajax({
url:'',//请求文件路径
type:'',//请求方式GET POST
data:{},//要发给服务器的数据参数
dataType:'',//希望接口返回的数据格式json,string等等
success:function(){
// 请求成功的回调
},
error:function(){
// 请求失败的回调
}
})
接下来,jq毕竟只是一个类库,原生js还是要弄清楚的,那原生的ajax怎么写呢:
一个ajax的请求可以形象的比喻为一次打电话的过程:
1 //1 拿出手机 创建XMLHttpRequest对象 2 //2 拨号 连接到服务器 3 //3 说话 发送请求 4 //4 等待对方回应 服务器响应请求 5 6 //1 拿出手机 创建XMLHttpRequest对象 7 if(window.XMLHttpRequest){ 8 var OAjax = new XMLHttpRequest() 9 }else{ 10 // 兼容ie6及以下写法 11 var OAjax = new ActiveXObject("Misrcsoft.XMLHTTP") 12 } 13 //2 拨号 连接到服务器 14 OAjax.open('GET','a.html?t="new Date().getTime()"','true');//请求方式,请求路径,t为了消除缓存,是否异步 15 //3 说话 发送请求 16 OAjax.send(); 17 //4 等待对方回应 服务器响应请求 18 OAjax.onreadystatechange = function(){ 19 //OAjax.readyState,监听浏览器和服务器之间的交互到哪一步了 20 // 0->未初始化,还没有调用open方法 21 // 1->载入,已调用send()方法,正在发送请求 22 // 2->载入完成,send()方法已完成,已收到全部响应内容 23 // 3->解析,解析响应的内容 24 // 4->完成,相应内容解析完成,可以在客户端调用 25 if(OAjax.readyState == 4){ 26 if(OAjax.status == 200){ 27 // 请求a.html成功,responseText为服务器响应的内容 28 console.log('ajax请求成功',OAjax.responseText); 29 30 }else{ 31 // 状态不为200 32 console.log('ajax请求失败'); 33 34 } 35 } 36 }
结语:个人觉得这个比喻还是比较好记的,如果你看到这篇博客,希望对你有帮助,over~
转载于:https://www.cnblogs.com/xiongyilin/p/9077302.html
最后
以上就是顺心小懒虫为你收集整理的面试时怎样回答:你对原生ajax的理解的全部内容,希望文章能够帮你解决面试时怎样回答:你对原生ajax的理解所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复