window.onload 不觸發的解決辦法

踩坑經歷

昨天我在寫前端代碼時,有個需求是:提交表單后,后臺返回一個數據到前端頁面的隱藏域中,在這個頁面加載完成后,判斷這個隱藏域中是否有內容,有則彈出后臺返回的信息。我首先想到的就是用 window.onload = function(){...} 的方式在頁面加載完后實現對應的操作。當我測試功能的時候,竟翻車了,window.onload 里面的內容完全不觸發。我也做了其它的測試,包括使用 jQuery 的 ready() 方法和 jQuery 自執行的方法來測試,這些方法能執行,但還是達不到我想要的效果,因為執行這些方法時,我后臺的返回的數據還沒有渲染到DOM中。

下面是測試時截圖:

  • 使用 alert() 阻塞來判斷 ready() 執行時,頁面情況
image-20200609143200738
  • alert() 阻塞時 DOM 元素顯示如下,head 和 body 是空的(可以看到我當時在找著解決方案,捂臉.jpg)
image-20200609143133634

上面的代碼,如果是使用 window.onload,是完全不執行

我也從瀏覽器頁面加載去想這個問題,但仍然想不到哪里出問題了,因為我的 js 代碼都寫在 body 的最下面。

后來找到一篇博客,說頁面元素如果有誤,那么 window.onload 將不會觸發,博客的網址我忘記記錄了,但我確定我的 html 和 css 代碼是沒問題的(因為我是用原本成功的頁面刪減了一些沒用標簽,就這一個頁面用同樣的邏輯寫 window.onload 的方法出問題了)。自己瞎鼓搗了挺久,特別是去檢查了后臺數據的傳參(雖然當時知道可能行不大,但萬一呢)。后來我想到了這篇博客說的頁面元素有錯誤,然后我突然有個想法,看看是不是我哪個js 方法寫錯了,然后把除 ready()window.onload 后面的全部方法都注釋掉了,就打算看看這兩個方法會不會觸發。果不其然,它成功運行并達到效果了,困擾我半天的問題終于解決了。順著這個思路下去,尋根溯源,我逐個把每個方法給放出來,最后終于找到了問題所在!我之前寫過了一個 window.onload 的方法!兩個window.onload 方法,默認會執行后面那個方法,所以我之前怎么測試都不觸發的原因就是因為寫了多個 window.onload 方法。(之前 js代碼 是直接復制過來修改的,沒有注意到這個細節,而且這兩個 window.onload 相隔了很多 js 方法)

那為什么 ready() 方法不能將后臺的返回到的數據渲染到 DOM 呢?

那就得從 window.onload 和 jQuery 的 ready() 方法的區別來講了。

  • window.onload

    所有元素加載完畢后才執行,包括圖片、CSS等所愿元素,無許考慮加載的次序問題,且只能執行一次。

  • (document).ready() 或者(function(){...}) 或者 (function(){...})(jQuery );

    DOM樹加載完成后執行,不需要等到所有元素加載完畢,且可以執行多次。

如果這兩個的還不是很懂的話,我們這里就講下瀏覽器的加載順序:

瀏覽器的加載和渲染順序是自上而下的,遇到 link,script 等會暫停解析,將控制權交給 JavaScript 解析,執行完畢之后再交給瀏覽器渲染引擎。詳細的渲染步驟如下:

  1. 加載 html
  2. 解析器解析html
  3. 創建 DOM 樹 ,加載CSS(加載完之后才能向下執行)
  4. 解析 CSS,講 CSS 作用于 DOM 節點上
  5. 遇到 js,先下載,如果操作了已經渲染完成的元素,則重新渲染
  6. 遇到圖片資源,向服務器發送請求,無需等待,繼續向下執行
  7. 返回圖片后,重新渲染這部分代碼
  8. 顯示所有渲染完成的畫面

從 html 渲染步驟我們可以看出,jQuery 的 ready() 方法是在第三步完成時執行的, window.onload 是在第八步時執行的。也就是說,jQuery 的 ready() 方法主要比 window.onload 先執行的,而 DOM 樹加載完成后,數據并不一定會加載完成。所以我之前的代碼,ready() 方法中不能將后臺的返回到的數據渲染到 DOM 就是這個原因。后臺返回的數據是在 DOM 樹創建完成后才修改 DOM 元素的。

那么這兩個方法我們要如何選擇使用呢?

我個人觀點是如果是:需要編寫功能性代碼,需要操作后臺返回的數據的使用 window.onload ,因為它不需要考慮加載順序的問題,jQuery 的 ready() 方法能做的 window.onload 基本都能做。看起來是不錯,但是比較致命的還是速度問題。很多操作可能并不需要等待全部頁面渲染完成,特別是 CSS、JS、圖片文件比較多或這些文件比較大的頁面,CSS 會阻塞頁面的渲染。所以,大部分場景下,我們使用 jQuery 的 ready() 方法比較多

講到這里,好像逐漸跑題了,那么我再來總結一下我百度找到的大部分解決方法還有我這個低級錯誤的解決方法吧

解決方案

  1. 檢查 js 代碼是否有多個 window.onloadwindow.onload 只能出現一次!

  2. 使用 jQuery 的 ready() 方法

    <script type="text/javascript">
        // 方式一
        $(document).ready(function(){
         // 具體操作
     });
     // 方式二
     $(function(){
            // 具體操作
        });
     // 方式三
        (function(){
            // 具體操作
        })(jQuery)
        
    </script>
    
  3. 從瀏覽器加載順序去思考,找出哪個加載環節出錯,并對應去解決

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,619評論 6 539
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,155評論 3 425
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,635評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,539評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,255評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,646評論 1 326
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,655評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,838評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,399評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,146評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,338評論 1 372
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,893評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,565評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,983評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,257評論 1 292
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,059評論 3 397
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,296評論 2 376