關于html和javascript在瀏覽器中的加載順序問題的討論

轉自:http://www.cnblogs.com/beyondstorm/archive/2008/09/17/1292940.html


前一陣子橫掃了javascript,當時自我感覺良好。現在一想,又覺得沒什么。今天的任務是把asp.net ajax中客戶端頁面生命周期那一章研究完。然而,因為這一章的內容使我產生了一些迷惑。這些疑惑在書中都沒有只字提及。

一、html頁面的詳細加載過程是什么呢?頁面元素在加載時的優先級是什么?

  二、javascript的作用域、變量的作用域、不同腳本段之間的關系?

  三、html頁面的生命周期?

  這些問題真的打中了我的死穴。不了解這些,我就無法透過asp.net ajax的框架看到其底層原理。只知其然而不知其所以然。

  在網上廣泛查閱資料的情況下。獲得了部分答案。

關于html的加載:

  總體上,html的是按從上到下的順序邊加載邊解析,邊生成dom對象,至于在html中夾雜的:

  document.write("xxxx");

  <script type="text/javascript" src="aaa.js"></script>

  之類的東西,它們的順序是怎樣的呢?還是一樣,如果在解析html時,遇到這些東西就會停止解析,轉而執行這些生成語句,如果中間插入外部鏈接,就轉而解析、執行外部鏈接對應的js。對于以下語句對于不同瀏覽器存在不同的結果:

  <script type="text/javascript" src="aaa.js"></script>

  在ie中。不會等待aaa.js下載并解析完的,會創建另一線程搞定它,而主線程則越過去。但在ff中。則會等待,直到aaa.js下載、解析、執行完畢。

關于javascript的執行情況,請見本文后面所附的參考資料,里面有詳盡的討論。

關于html中頁面的生命周期:

  最重要的兩個事件就是onLoad、onUnLoad。onLoad在頁面加載完畢的時候觸發。onUnLoad在頁面的dom銷毀完后觸發。不過,onLoad有點特殊狀況,也請參見本文后面所附的參考資料。一定要引起注意。

  我看了幾個站點的html源碼,發現如下代碼:

<div class="ad1602"><script src="/ggjs/view1602_w.js"></script></div>

  這是某網站在頁面中顯示廣告的代碼,國內網站,顯示廣告一般都是用iframe來引入第三方頁面,這兒卻是直接用javascript段來生成。后來,我又看了163博客生成的html代碼,超變態啊。整個html代碼只有一個架子,所有頁面的生成都是通過js。我看到它的頁面后面引入了幾個js文件,最后在頁面最后還有一個initAll函數的調用。我沒有去仔細研究它的js代碼,我懷疑它把所有表現層的功能全面放到客戶端的js文件中去了。服務器端僅僅是很少的頁面架子和許多的webservices。真是嘆為觀止啊。

關于一個事件觸發多個響應函數:

  我曾想過要自己實現一個c#中委托一樣的東西。可以讓javascript的事件不止是關聯到一個function。可以一次觸發一個事件列表。這幾天研究asp.net ajax,里面對此有封裝。

  asp.net ajax中,可以把一個dom元素封裝成asp.net ajax中的Sys.UI.DomElement對象。然后就可以用它的方法:addHandler()、addHandlers()、removeHander()來操作事件列表。真是方便啊。當時不大明白這個原理。今天看到后面參考資料中的兩段代碼讓我徹底明白這中間的細節:

  一、使用dom 2中的接口:

  if(document.addEventListener){
    window.addEventListener('load',f,false);
    window.addEventListener('load',f1,false);
    ……
  }else{
    window.attachEvent('onload',f);
    window.attachEvent('onload',f1);
    ……
  }

  原來,dom中早有這個概念了。才曉得。看來,我對dom還是有許多不了解的地方啊。

  二、這個方法就是純手實現了。請參見下面代碼:

function addLoadEvent(func) {

?? var oldonload = window.onload;

?? if (typeof window.onload != 'function') {

    window.onload = func;

?? } else {

???? window.onload = function() {

?????? if (oldonload) {

???????? oldonload();

?????? }

?????? func();

???? }

?? }

}

這個函數寫得很巧妙。利用匿名函數搞定!

參考資料:

javascript 控制優化頁面 js 加載順序

html的加載過程

動態加載外部css或js文件

如何減少網頁的內存與CPU占用

Javascript在頁面加載時的執行順序

document.onLoad事件的奇怪現象

javascript中的attachEvent與addEventListener

判斷一個變量是否定義的方法

居然有js寫的Virtual OS


轉載于:https://www.cnblogs.com/jubincn/archive/2012/09/29/3381156.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/260356.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/260356.shtml
英文地址,請注明出處:http://en.pswp.cn/news/260356.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

java 觀察者模式_Java技術干貨分享:深入理解觀察者模式原理與技術

來源&#xff1a;編程技術精選觀察者模式(Observer Pattern)也叫做發布-訂閱(Publish/Subscribe)模式、模型-視圖(Model/View)模式。這個模式的一個最重要的作用就是解耦。也就是將被觀察者和觀察者進行解耦&#xff0c;使得他們之間的依賴性更小&#xff0c;甚至做到毫無依賴。…

python導入pyecharts錯誤沒有pyecharts_python報No module named 'pyecharts'的錯誤怎么辦?

問&#xff1a;導包的時候報No module named pyecharts的錯誤怎么辦&#xff1f;答&#xff1a;報上述錯誤一般是因為pyecharts這個包沒有下載成功&#xff0c;下面給大家介紹一下pyecharts庫的安裝與使用方法&#xff01;pyecharts是Python的數據可視化庫&#xff0c;可以幫助…

iOS開發:AFNetworking、MKNetworkKit和ASIHTTPRequest比較

轉&#xff1a;http://www.xue5.com/Mobile/iOS/747036.html 之前一直在使用ASIHTTPRequest作為網絡庫&#xff0c;但是由于其停止更新&#xff0c;iOS7上可能出現更多的問題&#xff0c;于是決定更換網絡庫。 目前比較流行的網絡庫主要有AFNetworking和MKNetworkKit&#xff…

java .listfiles_Java File.listFiles()

全屏Java Java File.listFiles()方法具有以下語法。public File [] listFiles()示例在下面的代碼顯示如何使用File.listFiles()方法。import java.io.File;// At: W w W. y I i ba I.C o mpublic class Main {public static void main(String[] args) {// create new fileFile …

基礎入門_Python-內建函數.運維開發中eval內建函數的最佳實踐?

簡單介紹:說明: 在指定命名空間中計算參數字符串的有效表達式,并返回一個對象,Help on built-in function eval in module __builtin__:eval(...)eval(source[, globals[, locals]]) -> valueEvaluate the source in the context of globals and locals.The source may be a…

java簡單畢設_計算機畢業設計之自定義畢設課題需要如何確定工作量

“ 真正讓導師滿意的不是眾多普通的功能&#xff0c;而是那一抹有創意的充滿著生活氣息的小功能。”自定義畢設課題&#xff0c;我覺得這是一種體現學生創新的一種很好的手段&#xff0c;但是有一些學生卻因為腦海中沒有積累足夠多的專業知識以及也沒有對現實生活進行足夠的思考…

C#基礎系列第五篇

前言&#xff1a; 完全是我在學習過程中記錄的筆記&#xff0c;只不過分享一下讓很多剛開始學習.net編程的人能夠很快的學會C#語言 多態的一些說明(1) 多態就是為了程序的可擴展性 (2)多態的使用&#xff1a;將不同的對象當作父類來看&#xff0c;屏蔽掉各個對象間的不同&#…

羅伯特·帕丁森Robert Pattinson(2)

2019獨角獸企業重金招聘Python工程師標準>>> 轉載于:https://my.oschina.net/Bettyty/blog/756873

網博士自助建站系統_自助建站:自助建站到底好還是不好?

自助建站到底好還是不好&#xff1f;很多想要做企業網站的企業都比較關心這個問題&#xff0c;因為自助建站便宜、快&#xff0c;有的自助建站做出來的效果還非常好&#xff0c;不輸于定制的網站的效果&#xff0c;那為什么自助建站大都還很便宜呢&#xff1f;東西還好還便宜的…

linux tar.gz zip 解壓縮 壓縮命令

http://apps.hi.baidu.com/share/detail/37384818 download ADT link http://dl.google.com/android/ADT-0.9.6.zip download SDK link http://dl.google.com/android/android-sdk_r11-linux_x86.tgz(能夠通過翻墻得到詳細的文件名稱&#xff0c;再通過鏈接下載就可以) tar -c:…

HNU 11720 God Created The Integers

原題傳送&#xff1a;http://acm.hnu.cn/online/?actionproblem&typeshow&id11720&courseid0 對于這條式子&#xff1a; 和下面的式子是等價的&#xff1a; Sp (p2 - 1) / 2 - (p - 1) / 4 那么求出Sp后有rp*Sp ≡ 1 (mod p)&#xff0c;用擴展GCD求出rp就行了。…

java equals 的區別_java中equals和==的區別是什么-百度經驗

在jdk1.5以上的版本中&#xff0c;基本類型和封裝類能自動轉化&#xff0c;與String類型的對象和字符串常量類似。Integer i1 123; Integer i2 123 int i 123; Integer i3 new Integer(123); Integer i4 new Integer(123); …

ps命令使用 進程查看

ps命令是Process Status的縮寫用來列出系統中當前運行的那些進程。ps命令列出的是當前那些進程的快照&#xff0c;就是執行ps命令的那個時刻的那些進程&#xff0c;如果想要動態的顯示進程信息&#xff0c;就可以使用top命令。使用該命令可以確定有哪些進程正在運行和運行的狀態…

stm32例程_如何學習STM32?

閱讀全文大約10min//封面為我現在使用的STM32型號&#xff1a;旗艦版 Stm32f103ZE//本文內容是對正點原子的資料整理參考資料&#xff1a;CM3權威指南/CM4權威指南&#xff08;ARM提供&#xff09;芯片參考手冊 STM32F10x中文參考手冊 芯片數據手冊 STM32F103xCDE_DS_CH_V5.pdf…

java compile_java中的CompileAPI入門及使用

介紹java5之前我們可以通過java提供的tools.jar來操作java編譯器&#xff0c;java6提供了新的API&#xff0c;讓我們可以更方便的調用。包名為javax.tools。使用通過文件編譯String filePath "D:\\Client.java";//獲取java編譯器JavaCompiler javaCompiler ToolPro…

《Two Days DIV + CSS》讀書筆記——CSS選擇器

1.1.2 CSS選擇器 CSS 選擇器最基本的有四種&#xff1a;標簽選擇器、ID 選擇器、類選擇器、通用選擇器。 【標簽選擇器】 一個完整的 HTML 頁面由很多不同的標簽組成&#xff0c;而標簽選擇器&#xff0c;則是決定哪些標簽采用相應的 CSS 樣式&#xff0c;比如&#xff0c;在 s…

TempDB為什么要根據CPU數目來決定文件個數

在SQL Server的世界中&#xff0c;SQL Server在Windows之上有一套自己的任務調度和資源分配系統&#xff0c;這使得SQL Server作為Windows的一個進程&#xff0c;卻可以處理大量的并發&#xff0c;這些任務調度和資源分配非常像一個操作系統&#xff0c;因此SQL Server在Window…

python基礎到實踐_一本書搞定Python入門到實踐

題圖&#xff1a;Photo by Aaron Burden on Unsplash上周介紹了幾本Python從入門到進階書籍&#xff0c;今天推薦一本入門好書《Python編程&#xff1a;從入門到實踐》&#xff0c;適合零基礎小白&#xff0c;也適合有其它語言背景的程序員。書中有哪些亮點&#xff1f;2016年出…

Linux網卡eth0變成eth1修改方法

由于換了主板&#xff0c;集成網卡mac地址變了&#xff0c;70-persistent-net.rules中仍然保留了老網卡的內容&#xff0c;新網卡則被識別為eth1。 將表示老網卡的行注釋掉&#xff0c;然后將表示新網卡的行中eth1改成eth0&#xff0c;在把網卡配置文件ifcfg-eth0的mac地址改成…

java微博模擬登陸_java 模擬登錄新浪微博(通過cookie)

這幾天一直在研究新浪微博的爬蟲&#xff0c;發現爬取微博的數據首先要登錄。本來打算是通過賬號和密碼模擬瀏覽器登錄。但是現在微博的登錄機制比較復雜。通過賬號密碼還沒有登錄成功QAQ。所以就先記錄下&#xff0c;通過cookie直接訪問自己的微博主頁。微博登錄的認證過程微博…