ajax的使用一直是以jQuery为主,对于底层的实现有点不明觉厉。做为一个有追求的前端,这是不能够接受的。便让咱们今晚好好走进ajax的心里世界。前端
ajax 两大特性:ajax
ajax 请求流程
step-1
首先先创建一个异步请求对象浏览器
var httpRequest if(window.XMLHttpRequest) { httpRequest = new XMLHttpRequest(); } else if(window.ActiveXObject) { httpRequest = new ActiveXObject("Microsoft.XMLHTTP"); }
step-2
第一步的httpRequest对象设置已经好了。而后咱们要作的就是设置咱们的请求被响应时的动做缓存
httpRequest.onreadystatechange = function(){ if(httpRequest.readyState === 4) { // everything is good, the response is received } else { // still not ready } }
readyState 说明服务器
Response 属性闭包
step-3
而后来写一个简单的demoapp
<span id="ajaxButton" style="cursor: pointer; text-decoration: underline"> Make a request </span> <script> (function(){ var httpRequest; if (window.XMLHttpRequest) { httpRequest = new XMLHttpRequest(); } else if(window.ActiveXObject) { httpRequest = new ActiveXObject("Microsoft.XMLHTTP"); } if (!httpRequest) { alert('Giving up :( (Cannot create an XMLHTTP instance'); return false; } httpRequest.onreaystatechange = function() { if (httpRequest.readyState === 4) { if (httpRequest.status === 200) { alert(httpRequest.responseText); } else { alert('There was a problem with the request.'); } } } httpRequest.open('GET', url); httpRequest.send(); })() </script>
爱心小贴士:异步
返回的数据为JSON时,应对数据进行相应的解析url
function alertContents() { if(httpRequest.readyState === 4) { if(httpRequest.status === 200) { var response = JSON.parse(httpRequest.responseText); } else { alert('There was s problem with the request.'); } } }