国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

window.onload 觸發(fā)時機問題

UsherChen / 2104人閱讀

摘要:本文關鍵點和頁面上的成功回調(diào)到底哪個先觸發(fā)。自己給了一個合理的解析會在當前任務隊列的最后一個觸發(fā)。如最開始的例子,異步,尚未給出結(jié)果,頁面需要等待的所有內(nèi)容已經(jīng)完成,任務隊列為空,因此觸發(fā)。

本文首發(fā)我的博客 - blog.cdswyda.com,轉(zhuǎn)載務必保留作者和出處,以便追溯和錯誤修正。

本文關鍵點: window.onload 和 頁面上 ajax 的成功回調(diào)到底哪個先觸發(fā)。

答案是不確定

問題詳情

之前遇到一個現(xiàn)象,在父頁面彈出一個Dialog加載一個子頁面,在onload回調(diào)中傳遞一個參數(shù)給子頁面,子頁面異步ajax成功回調(diào)中要使用這個變量。

然而出現(xiàn)的情況是在ajax的成功回調(diào)中大多數(shù)情況下是取不到這個在onload傳來的值,但是偶爾又是可以的。

查閱此Dialog源碼,以上邏輯可以進行如下簡化。

父頁面:


子頁面:

由于iframe的 onload 即要加載頁面的 window.onload ,因此情況可以進一步簡化為一個頁面中到底是 window.onload 先觸發(fā)還是 ajax 的成功回調(diào)先觸發(fā)。

測試代碼:

這個頁面除了在測試的script之前引入了jQuery沒有其他代碼,應該毫無疑問,是 window.onload 先觸發(fā),之后才是 ajax 的成功結(jié)果。

結(jié)果也證明是 window.onload 先觸發(fā),上面代碼在瀏覽器運行結(jié)果為:

// window onload
// Event {}
// ajax結(jié)果
// {}

MDN上關于 window.onload 有如下解釋:

The load event fires at the end of the document loading process. At this point, all of the objects in the document are in the DOM, and all the images, scripts, links and sub-frames have finished loading.

那么問題就來了,如果必然是 window.onload 先觸發(fā),那么是不可能出現(xiàn)最開始的問題的。

偽解釋

繼續(xù)修改測試代碼,再加上一些東西:

寫入一個一分鐘的循環(huán)后,結(jié)果發(fā)生了改變:

// ajax結(jié)果
// {}
// window onload
// Event {}

這么來看就奇怪了呀, ajax 的成功比 window.onload 先觸發(fā)。

關于這個現(xiàn)象,我也沒找到權威的解釋。

自己給了一個“合理”的解析:

window.onload 會在當前任務隊列的最后一個觸發(fā)。如最開始的例子,ajax 異步,尚未給出結(jié)果,頁面需要等待的所有內(nèi)容已經(jīng)完成,任務隊列為空,因此 window.onload 觸發(fā)。

而后面這個由于 ajax 后面還有很長的代碼要執(zhí)行,這段代碼推遲了 onload 的觸發(fā),同時這段代碼還未執(zhí)行完成時,之前異步的ajax已經(jīng)返回了結(jié)果,成功回調(diào)的代碼已經(jīng)被加到了任務隊列,因此 ajax 回調(diào)執(zhí)行后才觸發(fā) window.onload

再驗證

為了進一步驗證我上面的想法,那么只要保證頁面資源執(zhí)行完成時,ajax還沒有解決即可。

因此還是上面的代碼,但是將請求的內(nèi)容換成一個真實接口,這個真實接口返回的數(shù)據(jù)更晚即可。

使用php暫停120s再返回結(jié)果,代碼如下:

結(jié)果卻是如上面估計的一樣:

// window onload
// Event {}
// ajax結(jié)果
// {"response":"two minutes later."}

可以說明之前的“合理”解釋確實是合理的。

所以異步的 ajaxwindow.onload 到底哪個會先觸發(fā)是不確定,和你js代碼(或者其他onload要等待的資源,如一個圖片加載很慢等)以及這個 ajax 的解決時間有關系。

因此這種情況下的傳值就不能以這種方式進行,可以換成更穩(wěn)妥的方式,如直接跨頁面操作或者放在url進行傳遞。

文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/90277.html

相關文章

  • 項目過程中的小學習

    摘要:淺灰色呈現(xiàn)該提示會在輸入字段為空時顯示,并會在字段獲得焦點時消失。在常規(guī)的代碼中,通常使用方法,而在中,使用的是方法。方法是事件模塊中最重要一個函數(shù),可以極大的提高應用程序的速度。 1.將多個同類元素分行,每一行有兩個或者多個元素,可用li標簽實現(xiàn)此 身高 ...

    wua_wua2012 評論0 收藏0
  • 項目過程中的小學習

    摘要:淺灰色呈現(xiàn)該提示會在輸入字段為空時顯示,并會在字段獲得焦點時消失。在常規(guī)的代碼中,通常使用方法,而在中,使用的是方法。方法是事件模塊中最重要一個函數(shù),可以極大的提高應用程序的速度。 1.將多個同類元素分行,每一行有兩個或者多個元素,可用li標簽實現(xiàn)此 身高 ...

    william 評論0 收藏0
  • 細說 jQuery 事件篇(一) - 代碼執(zhí)行時機

    摘要:在元素一篇介紹過,可以使用來使得代碼在加載完畢后自動執(zhí)行代碼,接下來具體介紹下這個機制。這樣看上去貌似沒什么問題,但是如果有兩個函數(shù)需要指定時就會遇到麻煩,因為屬性只能保存對一個函數(shù)的引用,如果我們寫成以下形式最后代碼執(zhí)行后的效果是會覆蓋。 在元素一篇介紹過,jQuery 可以使用 $(document).ready() 來使得代碼在 DOM 加載完畢后自動執(zhí)行代碼,接下來具體介紹下這...

    dunizb 評論0 收藏0
  • 簡記html中常用的文檔加載方法

    摘要:簡介最近對于文檔加載方法有了新的理解,因此整理成一片簡記,方便以后進行查閱。此狀態(tài)為樹構建完成后觸發(fā),和一樣,但在其之后觸發(fā)兼容性以上可用方法當瀏覽器窗口,文檔或其資源將要卸載時,會觸發(fā)事件。沒有賦值時,該事件不做任何響應。 簡介 最近對于文檔加載方法有了新的理解,因此整理成一片簡記,方便以后進行查閱。先來一段Html,作為我們研究的基礎吧。 ...

    gaosboy 評論0 收藏0
  • 簡記html中常用的文檔加載方法

    摘要:簡介最近對于文檔加載方法有了新的理解,因此整理成一片簡記,方便以后進行查閱。此狀態(tài)為樹構建完成后觸發(fā),和一樣,但在其之后觸發(fā)兼容性以上可用方法當瀏覽器窗口,文檔或其資源將要卸載時,會觸發(fā)事件。沒有賦值時,該事件不做任何響應。 簡介 最近對于文檔加載方法有了新的理解,因此整理成一片簡記,方便以后進行查閱。先來一段Html,作為我們研究的基礎吧。 ...

    shenhualong 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<