首頁  >  文章  >  後端開發  >  javascript - ajax的非同步問題

javascript - ajax的非同步問題

WBOY
WBOY原創
2016-08-04 09:19:55867瀏覽

javascript - ajax的非同步問題

請問ajax 裡面的回呼函數是返回data再執行函數裡面的程式碼還是不等data回傳就直接執行函數裡面的程式碼的呢?

如果是第二種情況,該如何避免異步帶來的困擾呢?

回覆內容:

javascript - ajax的非同步問題

請問ajax 裡面的回呼函數是返回data再執行函數裡面的程式碼還是不等data回傳就直接執行函數裡面的程式碼的呢?

如果是第二種情況,該如何避免異步帶來的困擾呢?

success的回呼函數是data成功返回後要執行的函數,也就是說要得到data之後才會執行
其他情況下的還有像beforeSend(發送前),complete(請求完成後),error(請求出錯)的回調

至於你說的異步帶來的困擾我不太明白,可以舉例說一下嗎?

一定是返回data再去執行函數裡面的程式碼= = 不回傳data就執行= =豈不是等著報錯。

ajax的全名AJAX = Asynchronous JavaScript and XML(非同步的 JavaScript 和 XML)。
先回答您的問題,success的情況下,當成功返回data以後,才會執行函數。沒有回來的話,會很乖巧的等待一會兒時間,這個時間通常是網路延遲時間。同時也可以自己設定。

下面以偉大的jquery框架的ajax簡單說下。
通常,我會這樣使用,name+value的形式。

<code>$.ajax({name:value, name:value, ... })</code>
  • async 布林值,表示請求是否非同步處理。預設是 true。 設定為false,你就關閉了異步,此時一次請求,介面會很卡。

  • beforeSend(xhr) 發送請求前運行的函數。

  • cache 布林值,表示瀏覽器是否快取被要求頁面。預設是 true。

  • complete(xhr,status) 請求完成時運行的函數(在請求成功或失敗之後均調用,即在 success 和 error 函數之後)。

  • contentType 發送資料到伺服器時所使用的內容類型。預設是:"application/x-www-form-urlencoded"。

  • context 為所有 AJAX 相關的回呼函數規定 "this" 值。

  • data 規定要傳送到伺服器的資料。

  • dataFilter(data,type) 用於處理 XMLHttpRequest 原始回應資料的函數。

  • dataType 預期的伺服器回應的資料類型。

  • error(xhr,status,error) 如果請求失敗要運行的函數。

  • global 布林值,規定是否為請求觸發全域 AJAX 事件處理程序。預設是 true。

  • ifModified 布林值,規定是否僅在最後一次請求以來回應發生變更時才請求成功。預設是 false。

  • jsonp 在一個 jsonp 中重寫回呼函數的字串。

  • jsonpCallback 在一個 jsonp 中規定回呼函數的名稱。

  • password 規定在 HTTP 存取認證請求中使用的密碼。

  • processData 布林值,規定透過請求傳送的資料是否轉換為查詢字串。預設是 true。

  • scriptCharset 規定請求的字元集。

  • success(result,status,xhr) 當請求成功時執行的函數。

  • timeout 設定本地的請求超時時間(以毫秒計)。

  • traditional 布林值,規定是否使用參數序列化的傳統樣式。

  • type 規定請求的類型(GET 或 POST)。

  • url 規定發送請求的 URL。預設是當前頁面。

  • username 規定在 HTTP 存取認證請求中使用的使用者名稱。 這個可以模擬用戶的登錄,再加上password,你懂的。

  • xhr 用於建立 XMLHttpRequest 物件的函數。

紅色部分,是我自己常用的。

等你要求的介面成功回應資料以後回呼這個success函數,所以只要你服務端處理正常,data回傳的就是你想要的資料

問題的答案,上面已經說了,我就不重複了,我只是想問一下你說的非同步的困擾有哪些。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn