window.onload用法詳解

来源:http://www.cnblogs.com/wzhiq896/archive/2016/10/12/5953974.html
-Advertisement-
Play Games

window.onload用法詳解:網頁中的javaScript腳本代碼往往需要在文檔載入完成後才能夠去執行,否則可能導致無法獲取對象的情況,為了避免這種情況的發生,可以使用以下兩種方式:一.將腳本代碼放在網頁的底端,這樣在運行腳本代碼的時候,可以確保要操作的對象已經載入完成。二.通過window. ...


window.onload用法詳解:
網頁中的javaScript腳本代碼往往需要在文檔載入完成後才能夠去執行,否則可能導致無法獲取對象的情況,為了避免這種情況的發生,可以使用以下兩種方式:
一.將腳本代碼放在網頁的底端,這樣在運行腳本代碼的時候,可以確保要操作的對象已經載入完成。
二.通過window.onload來執行腳本代碼。
第一種方式感覺比較凌亂(其實推薦使用),往往我們需要將腳本代碼放在一個更為合適的地方,那麼window.onload方式就是一個良好的選擇。window.onload是一個事件,當文檔載入完成之後就會觸發該事件,可以為此事件註冊事件處理函數,並將要執行的腳本代碼放在事件處理函數中,於是就可以避免獲取不到對象的情況。先看一段代碼實例:

[HTML] 純文本查看 複製代碼運行代碼    <!DOCTYPE html>   <html>   <head>   <meta charset=" utf-8">   <meta name="author" content="http://www.cnblogs.com/wzhiq896/" /> <title>window.onload用法</title> <style type="text/css"> #bg{   width:100px;   height:100px;   border:2px solid red; } </style> <script type="text/javascript"> document.getElementById("bg").style.backgroundColor="#F90"; </script> </head> <body>   <div id="bg"></div> </body> </html>

以上代碼的初衷是向將div的背景顏色設置為#F90,但是並沒有實現此效果,這是因為代碼是順序執行的,當執行到document.getElementById("#bg").style.backgroundColor="#F90"這一句的時候,還沒有載入到此div對象,所以設置也就不能夠成功。代碼修改如下:

[HTML] 純文本查看 複製代碼運行代碼 <!DOCTYPE html>   <html>   <head>   <meta charset=" utf-8">   <meta name="author" content="http://www.cnblogs.com/wzhiq896/" /> <title>位置高度div垂直居中</title> <style type="text/css"> #bg{   width:100px;   height:100px;   border:2px solid red; } </style> <script type="text/javascript"> window.onload=function(){   document.getElementById("bg").style.backgroundColor="#F90"; } </script> </head> <body>   <div id="bg"></div> </body> </html>

以上代碼實現了將div背景顏色設置為#F90的目的。原因就是講設置背景顏色的代碼放置在window.onload的事件處理函數中,只有當文檔載入完成後,才會執行事件處理函數,也才會執行設置背景顏色的腳本代碼。
事件處理函數綁定:
方式一:
window.onload=function(){},在以上代碼中就是使用此種方式為window.onload事件綁定事件處理函數,這裡綁定的是一個匿名函數,當然也可以綁定非匿名函數,代碼實例如下:

[HTML] 純文本查看 複製代碼運行代碼 <!DOCTYPE html>   <html>   <head>   <meta charset=" utf-8">   <meta name="author" content="http://www.cnblogs.com/wzhiq896/" /> <title>window.onload</title> <script type="text/javascript"> window.onload=function myalert() {   alert("綁定成功!"); } </script> </head> <body>   </body> </html>

以上代碼可以將為名myalert方法綁定到window.onload事件上,但是不能以以下方式為此事件綁定多個事件處理函數:

[JavaScript] 純文本查看 複製代碼運行代碼      window.onload=function a(){} window.onload=function b(){}


以上代碼並不能為window.onload事件綁定多個事件處理函數,而是最後一個會覆蓋前面的所有函數。不過代碼可以變通一下:

[HTML] 純文本查看 複製代碼運行代碼 <!DOCTYPE html>   <html>   <head>   <meta charset=" utf-8">   <meta name="author" content="http://www.cnblogs.com/wzhiq896/" /> <title>window.onload用法</title> <style type="text/css"> #bg{   width:100px;   height:100px;   border:2px solid red; } </style> <script type="text/javascript"> window.onload=function(){   function a(){     document.getElementById("bg").style.backgroundColor="#F90";   }   function b(){     document.getElementById("bg").style.width="200px";   }   a();   b(); } </script> </head> <body>   <div id="bg"></div> </body> </html>

以上代碼實現了綁定多個事件處理函數同樣的效果。
方式二:
可以使用addEventListener()attachEvent()為onload事件綁定事件處理函數,下麵分別介紹一下:
addEventListener()是當前標準的一種事件處理函數綁定方式,但是IE8和IE8以下的瀏覽器並不支持此方式,實例如下:

[HTML] 純文本查看 複製代碼運行代碼 <!DOCTYPE html>   <html>   <head>   <meta charset=" utf-8">   <meta name="author" content="http://www.cnblogs.com/wzhiq896/" /> <title>window.onload用法</title> <style type="text/css"> #bg{   width:100px;   height:100px;   border:2px solid red; } </style> <script type="text/javascript"> window.addEventListener("load",bg,false); window.addEventListener("load",changeW,false); function bg(){   document.getElementById("bg").style.backgroundColor="#F90"; } function changeW(){   document.getElementById("bg").style.width="200px"; } </script> </head> <body>   <div id="bg"></div> </body> </html>

以上代碼可以為window.onload事件綁定多個事件處理函數。簡單介紹一下語法格式:

[JavaScript] 純文本查看 複製代碼運行代碼 addEventListener("type",函數名,false)


addEventListener()函數具有三個參數,第一個參數事件類型,需要註意的是,事件類型名稱前面不能有on,例如window.onload事件,在這個地方只能寫作load,第二個參數是要綁定的函數名稱,第三個參數一般為false。
使用attachEvent()函數綁定事件處理函數:
IE9之前的的IE瀏覽器不支持addEventListener()函數,所以attachEvent()函數就有了用武之地了,代碼實例如下:

[HTML] 純文本查看 複製代碼運行代碼 <!DOCTYPE html>   <html>   <head>   <meta charset=" utf-8">   <meta name="author" content="http://www.cnblogs.com/wzhiq896/" /> <title>window.onload用法</title> <style type="text/css"> #bg{   width:100px;   height:100px;   border:2px solid red; } </style> <script type="text/javascript"> window.attachEvent("onload",bg); window.attachEvent("onload",changeW); function bg(){   document.getElementById("bg").style.backgroundColor="#F90"; } function changeW(){   document.getElementById("bg").style.width="200px"; } </script> </head> <body>   <div id="bg"></div> </body> </html>

以上代碼的效果和使用addEventListener()函數的效果是一樣的,簡單介紹一下語法格式:

[JavaScript] 純文本查看 複製代碼運行代碼 addEventListener("type",函數名)


此函數只有兩個參數,第一個參數是事件類型,不過它和addEventListener()的第一個參數的作用是一樣,但是名稱有所區別,名稱前面是具有"on",第二個參數就是要綁定的事件處理函數名稱。為了相容各瀏覽器,需要將以上代碼進行改造,實例如下:

[HTML] 純文本查看 複製代碼運行代碼 <!DOCTYPE html>   <html>   <head>   <meta charset=" utf-8">   <meta name="author" content="http://www.cnblogs.com/wzhiq896/" /> <title>window.onload用法</title> <style type="text/css"> #bg{   width:100px;   height:100px;   border:2px solid red; } </style> <script type="text/javascript"> if(window.addEventListener){   window.addEventListener("load",bg,false);   window.addEventListener("load",changeW,false); } else{   window.attachEvent("onload",bg);   window.attachEvent("onload",changeW); }   function bg(){   document.getElementById("bg").style.backgroundColor="#F90"; } function changeW(){   document.getElementById("bg").style.width="200px"; } </script> </head> <body>   <div id="bg"></div> </body> </html>

以上代碼代碼解決了各大瀏覽器的相容性問題。在上面代碼中使用以下代碼進行判斷:

[JavaScript] 純文本查看 複製代碼運行代碼 if(object.addEventListener){   object.addEventListener(); } else{   object.attachEvent(); }

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、簡單工廠模式 簡單工廠模式,提供了一種創建對象的便捷方法。創建者通過不同的類型參數,創建相對應的對象。 實現代碼如下: 優點: 在創建固定類型的對象時,比較簡單好用。 缺點: 1. 在添加對象類型時,需要更改Creator類裡面的函數,違反了軟體設計中的開閉原則。 2. Creator類依賴於具 ...
  • Atitit. Atiposter 發帖機 新特性 poster new feature v7 q39 V8 重構iocutilV4,use def iocFact...jettyUtil V8 gui 獨立的gui..使用jetty.. V1 初步實現sina csdn cnblogs V2 實現 ...
  • 在DOM事件深入淺出(一)中,我主要給大家講解了不同DOM級別下的事件處理程式,同時介紹了事件冒泡和捕獲的觸發原理和方法。本文將繼續介紹DOM事件中的知識點,主要側重於DOM事件中Event對象的屬性和方法。 那麼什麼是DOM事件中Event對象呢?事件對象(event object)指的是與特定事 ...
  • 本人是軟體開發的初學者,總結了一點點日常所學,記錄在此,主要目的是鼓勵自己堅持學習,怕有一天忘記了,還能複習曾經學過的知識點。 如有大神路過為我指點迷津,糾正改錯更是感激不盡,但請不要噴我這個菜鳥!謝謝 jQuery Mobile的基本使用方法和簡單的知識點 安裝: <link rel="style ...
  • 網上有很多這方面的教程,但不是苦澀難懂就是從哪copy過來的,反正很長一段時間我是沒看懂,時間長了也沒打算去研究了,主要原因是,基本上很少會遇到那些問題(所以說啊,要是沒有研究精神的才懶得管它)。但自從開始研究CSS以後就一發不可收拾,所以打算把CSS一系列的東西都給研究一遍,當然能研究懂自然是好的 ...
  • js中的不同的數據類型之間的比較轉換規則如下: 1. 對象和布爾值比較 對象和布爾值進行比較時,對象先轉換為字元串,然後再轉換為數字,布爾值直接轉換為數字 2. 對象和字元串比較 對象和字元串進行比較時,對象轉換為字元串,然後兩者進行比較。 3. 對象和數字比較 對象和數字進行比較時,對象先轉換為字 ...
  • 為什麼計算寬度計算網頁像素寬度是為了CSS網頁佈局整齊與相容。常見的我們佈局左右結構網頁或使用padding、margin佈局的時候將計算整頁寬度,如果不計算無論是寬度過大過小就會出現錯位問題。 怎麼計算CSS寬度例一:我們計算一個左右結構的佈局樣式。假如總寬度為400px,那麼左右加起來就應當小於 ...
  • jquery實現圖片切換: javascript實現圖片切換: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...