一.什麼是同步請求:(false)
同步請求便是當前發出請求後,瀏覽器什麼都不能作,必須得等到請求完成返回數據以後,纔會執行後續的代碼,至關因而排隊,前一我的辦理完本身的事務,下一我的才能接着辦。也就是說,當JS代碼加載到當前AJAX的時候會把頁面裏全部的代碼中止加載,頁面處於一個假死狀態,當這個AJAX執行完畢後纔會繼續運行其餘代碼頁面解除假死狀態。
二.什麼是異步請求:(true)
異步請求就當發出請求的同時,瀏覽器能夠繼續作任何事,Ajax發送請求並不會影響頁面的加載與用戶的操做,至關因而在兩條線上,各走各的,互不影響。
通常默認值爲true,異步。異步請求能夠徹底不影響用戶的體驗效果,不管請求的時間長或者短,用戶都在專心的操做頁面的其餘內容,並不會有等待的感受。
有人說:既然異步這麼好,那所有都用異步好了,同步存在還有什麼意義?
那麼,同步適用於一些什麼狀況呢?
咱們能夠想一下,同步是一步一步來操做,等待請求返回的數據,再執行下一步,那麼必定會有一些狀況,只有這一步執行完,拿到數據,經過獲取到這一步的數據來執行下一步的操做。這是異步沒有辦法實現的,所以同步的存在必定有他存在的道理。web
Ajax優缺點
Ajax優勢和缺點:
優勢:
傳統的web應用容許用戶填寫表單(form),當提交表單時就向web服務器發送一個請求。服務器接收並處理傳來的表單,而後返回一個新的網頁。這個作法浪費了許多帶寬,由於在先後兩個頁面中的大部分HTML代碼每每是相同的。因爲每次應用的交互都須要向服務器發送請求,應用的響應時間就依賴於服務器的響應時間。這致使了用戶界面的響應比本地應用慢得多。
與此不一樣,AJAX應用能夠僅向服務器發送並取回必需的數據,它使用SOAP或其它一些基於XML的web service接口,並在客戶端採用JavaScript處理來自服務器的響應。由於在服務器和瀏覽器之間交換的數據大量減小,結果咱們就能看到響應更快的應用。同時不少的處理工做能夠在發出請求的客戶端機器上完成,因此Web服務器的處理時間也減小了。
使用Ajax的最大優勢,就是能在不更新整個頁面的前提下維護數據。這使得Web應用程序更爲迅捷地迴應用戶動做,並避免了在網絡上發送那些沒有改變過的信息。
Ajax不須要任何瀏覽器插件,但須要用戶容許JavaScript在瀏覽器上執行。就像DHTML應用程序那樣,Ajax應用程序必須在衆多不一樣的瀏覽器和平臺上通過嚴格的測試。隨着Ajax的成熟,一些簡化Ajax使用方法的程序庫也相繼問世。一樣,也出現了另外一種輔助程序設計的技術,爲那些不支持JavaScript的用戶提供替代功能。
缺點:
對應用Ajax最主要的批評就是,它可能破壞瀏覽器後退按鈕的正常行爲[4]。在動態更新頁面的狀況下,用戶沒法回到前一個頁面狀態,這是由於瀏覽器僅能記下歷史記錄中的靜態頁面。一個被完整讀入的頁面與一個已經被動態修改過的頁面之間的差異很是微妙;用戶一般都但願單擊後退按鈕,就可以取消他們的前一次操做,可是在Ajax應用程序中,卻沒法這樣作。不過開發者已想出了種種辦法來解決這個問題,當中大多數都是在用戶單擊後退按鈕訪問歷史記錄時,經過創建或使用一個隱藏的IFRAME來重現頁面上的變動。(例如,當用戶在Google Maps中單擊後退時,它在一個隱藏的IFRAME中進行搜索,而後將搜索結果反映到Ajax元素上,以便將應用程序狀態恢復到當時的狀態。)
一個相關的觀點認爲,使用動態頁面更新使得用戶難於將某個特定的狀態保存到收藏夾中。該問題的解決方案也已出現,大部分都使用URL片段標識符(一般被稱爲錨點,即URL中#後面的部分)來保持跟蹤,容許用戶回到指定的某個應用程序狀態。(許多瀏覽器容許JavaScript動態更新錨點,這使得Ajax應用程序可以在更新顯示內容的同時更新錨點。)這些解決方案也同時解決了許多關於不支持後退按鈕的爭論。 進行Ajax開發時,網絡延遲——即用戶發出請求到服務器發出響應之間的間隔——須要慎重考慮。不給予用戶明確的迴應 [5],沒有恰當的預讀數據 [6],或者對XMLHttpRequest的不恰當處理[7],都會使用戶感到延遲,這是用戶不欲看到的,也是他們沒法理解的[8]。一般的解決方案是,使用一個可視化的組件來告訴用戶系統正在進行後臺操做而且正在讀取數據和內容。瀏覽器
一些手持設備(如手機、PDA等)如今還不能很好的支持Ajax; 用JavaScript做的Ajax引擎,JavaScript的兼容性和DeBug都是讓人頭痛的事; Ajax的無刷新重載,因爲頁面的變化沒有刷新重載那麼明顯,因此容易給用戶帶來困擾――用戶不太清楚如今的數據是新的仍是已經更新過的;現有的解決有:在相關位置提示、數據更新的區域設計得比較明顯、數據更新後給用戶提示等; 對串流媒體的支持沒有FLASH、Java Applet好;服務器