ajax是通過jquery封裝的,咱們能夠用原生的js去制定ajax;jquery
大概的步驟:ajax
1.創建xmlHttpRequrest鏈接;json
2.請求向臺臺服務器發送請求;瀏覽器
3.根據服務器返回狀態碼進行相關的操做.服務器
4.返回的數據進行格式化;app
ajax({ url: "./TestXHR.aspx", //請求地址 type: "POST", //請求方式 data: { name: "super", age: 20 }, //請求參數 dataType: "json", success: function (response, xml) { // 此處放成功後執行的代碼 }, fail: function (status) { // 此處放失敗後執行的代碼 } }); function ajax(options) { options = options || {}; options.type = (options.type || "GET").toUpperCase(); options.dataType = options.dataType || "json"; var params = formatParams(options.data); //建立 - 非IE6 - 第一步 if (window.XMLHttpRequest) { var xhr = new XMLHttpRequest(); } else { //IE6及其如下版本瀏覽器 var xhr = new ActiveXObject('Microsoft.XMLHTTP'); } //接收 - 第三步 xhr.onreadystatechange = function () { if (xhr.readyState == 4) { var status = xhr.status; if (status >= 200 && status < 300) { options.success && options.success(xhr.responseText, xhr.responseXML); } else { options.fail && options.fail(status); } } } //鏈接 和 發送 - 第二步 if (options.type == "GET") { xhr.open("GET", options.url + "?" + params, true); xhr.send(null); } else if (options.type == "POST") { xhr.open("POST", options.url, true); //設置表單提交時的內容類型 xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); xhr.send(params); } } //格式化參數 function formatParams(data) { var arr = []; for (var name in data) { arr.push(encodeURIComponent(name) + "=" + encodeURIComponent(data[name])); } arr.push(("v=" + Math.random()).replace(".","")); return arr.join("&"); }