首頁  >  文章  >  web前端  >  AJAX與JavaScript的使用詳解

AJAX與JavaScript的使用詳解

php中世界最好的语言
php中世界最好的语言原創
2018-03-31 13:39:331463瀏覽

這次帶給大家AJAX與JavaScript的使用詳解,AJAX與JavaScript使用的注意事項有哪些,以下就是實戰案例,一起來看一下。

AJAX不是JavaScript的規範,它只是一個哥們「發明」的縮寫:Asynchronous JavaScript and XML,意思是用JavaScript執行非同步網路請求。

如果仔細觀察一個Form的提交,你就會發現,一旦使用者點擊「Submit」按鈕,表單開始提交,瀏覽器就會刷新頁面,然後在新頁面裡告訴你操作是成功了還是失敗了。如果不幸因為網路太慢或其他原因,就會得到一個404頁面。

這就是Web的運作原理:一次HTTP請求對應一個頁面。

如果要讓使用者留在目前頁面中,同時發出新的HTTP請求,就必須用JavaScript發送這個新請求,接收到資料後,再用JavaScript更新頁面,這樣一來,用戶就感覺自己仍然停留在目前頁面,但是數據卻可以不斷地更新。

最早大規模使用AJAX的就是Gmail,Gmail的頁面在首次載入後,剩下的所有資料都依賴AJAX來更新。

用JavaScript寫一個完整的AJAX程式碼並不複雜,但要注意:AJAX請求是非同步執行的,也就是說,要透過回呼函數獲得回應。
在現代瀏覽器上寫AJAX主要依靠XMLHttpRequest物件:

function success(text) {
 var textarea = document.getElementById('test-response-text');
 textarea.value = text;
}
function fail(code) {
 var textarea = document.getElementById('test-response-text');
 textarea.value = 'Error code: ' + code;
}
var request = new XMLHttpRequest(); // 新建XMLHttpRequest对象
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('请求已发送,请等待响应...');

對於低版本的IE,需要換一個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('请求已发送,请等待响应...');

如果你想把標準寫法和IE寫法混在一起,可以這麼寫:

var request;
if (window.XMLHttpRequest) {
 request = new XMLHttpRequest();
} else {
 request = new ActiveXObject('Microsoft.XMLHTTP');
}

透過偵測window物件是否有XMLHttpRequest屬性來決定瀏覽器是否支援標準的XMLHttpRequest#。請注意,不要根據瀏覽器的navigator.userAgent來偵測瀏覽器是否支援某個JavaScript特性,一是因為這個字串本身可以偽造,二是透過IE版本判斷JavaScript特性將非常複雜。

當建立了XMLHttpRequest物件後,要先設定onreadystatechange的回呼函數。在回呼函數中,通常我們只需透過readyState === 4判斷請求是否完成,如果已完成,再根據status === 200判斷是否是一個成功的回應。
XMLHttpRequest物件的open()方法有3個參數,第一個參數指定是GET還是POST,第二個參數指定URL位址,第三個參數指定是否使用非同步,預設是true#,所以不用寫。

注意,千萬不要把第三個參數指定為false,否則瀏覽器將停止回應,直到AJAX請求完成。如果這個請求耗時10秒,那麼10秒內你會發現瀏覽器處於「假死」狀態。

最後呼叫send()方法才真正傳送請求。 GET請求不需要參數,POST請求需要把body部分以字串或是FormData物件傳進去。

安全限制

上面程式碼的URL使用的是相對路徑。如果你把它改為'http://www.sina.com.cn/'#,再運行,肯定報錯。在Chrome的控制台裡,還可以看到錯誤訊息

這是因為瀏覽器的同源策略所導致的。預設情況下,JavaScript在發送AJAX請求時,URL的網域必須和目前頁面完全一致。

完全一致的意思是,域名要相同(www.example.comexample.com不同),协议要相同(http和https不同),端口号要相同(默认是:80端口,它和:8080就不同)。有的浏览器口子松一点,允许端口不同,大多数浏览器都会严格遵守这个限制。

那是不是用JavaScript无法请求外域(就是其他网站)的URL了呢?方法还是有的,大概有这么几种:

一是通过Flash插件发送HTTP请求,这种方式可以绕过浏览器的安全限制,但必须安装Flash,并且跟Flash交互。不过Flash用起来麻烦,而且现在用得也越来越少了。

二是通过在同源域名下架设一个代理服务器来转发,JavaScript负责把请求发送到代理服务器:
'/proxy?url=http://www.sina.com.cn'代理服务器再把结果返回,这样就遵守了浏览器的同源策略。这种方式麻烦之处在于需要服务器端额外做开发。

第三种方式称为JSONP,它有个限制,只能用GET请求,并且要求返回JavaScript。这种方式跨域实际上是利用了浏览器允许跨域引用JavaScript资源:

<html>
<head>
 <script src="http://example.com/abc.js"></script>
 ...
</head>
<body>
...
</body>
</html>

JSONP通常以函数调用的形式返回,例如,返回JavaScript内容如下:
foo('data');这样一来,我们如果在页面中先准备好foo()函数,然后给页面动态加一个