下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第在頁面加載之后執(zhí)行JavaScript我們都知道,頁面加載是有順序的。讓我們先來理一下頁面的展示過程:
當(dāng)你輸入url并按下回車時(shí)
首先從本地查找域名,有的話直接用hosts文件里的ip地址,否則查詢DNS,得到ip地址建立TCP連接進(jìn)行三次握手客戶端發(fā)送http請求服務(wù)端處理,并返回結(jié)果給客戶端關(guān)閉TCP連接需要四次揮手瀏覽器收到結(jié)果,開始解析資源(JS、CSS、HTML),解析HTML生成的dom樹,和同時(shí)解析css生成的cssom樹結(jié)合生成渲染樹根據(jù)渲染樹渲染頁面
當(dāng)然,再詳細(xì)的比如:如何解析生成DOM樹、瀏覽器在三次握手四次揮手的同時(shí)做了什么、CSSOM樹是怎么和DOM樹一一對應(yīng)的這些如果你不是在做系統(tǒng),似乎是無關(guān)緊要的至少對本文來說是這樣的。
經(jīng)過上面的步驟,瀏覽器已經(jīng)拿到了想要的結(jié)果,下一步:瀏覽器渲染進(jìn)程啟用多個(gè)線程協(xié)助完成頁面渲染
GUI渲染線程,負(fù)責(zé)渲染瀏覽器界面,解析HTML、css,構(gòu)建DOM樹和RenderObject樹,布局和繪制一旦界面因?yàn)槟撤N操作引發(fā)了回流,此線程就會(huì)執(zhí)行JS引擎線程和GUI線程互斥,在js引擎執(zhí)行時(shí),GUI線程被掛起事件觸發(fā)線程依賴js的隊(duì)列機(jī)制完成(當(dāng)一個(gè)事件觸發(fā)時(shí)該線程會(huì)把事件添加到待處理隊(duì)列的隊(duì)尾,等待js引擎處理)定時(shí)器觸發(fā)線程依賴js的隊(duì)列機(jī)制完成異步http請求線程
這其中有一個(gè)重要的地方:JavaScript執(zhí)行線程和渲染線程互斥!而且JavaScript線程的優(yōu)先級(jí)最高!
所以一旦在HTML中發(fā)現(xiàn)了script,瀏覽器便會(huì)暫停其余HTML元素的顯示轉(zhuǎn)而去馬上加載JS代碼,這可能會(huì)導(dǎo)致兩個(gè)問題的發(fā)生:
頁面「一片空白」報(bào)錯(cuò)JS無法訪問未知(還沒開始的)加載內(nèi)容
所以,我們需要一種方法來暫停JS執(zhí)行。
很多人第一時(shí)間會(huì)選擇window.onload:恕我直言,這確實(shí)不是好的方法,它讓用戶等的太久了。你稍微一查就能知道:onload方法會(huì)等待頁面上所有的文字、table、img加載完成后才觸發(fā)。如果你真的要用,筆者倒是更推薦DOMContentLoaded,這個(gè)onload的變異產(chǎn)品會(huì)等到文字加載完成后立即觸發(fā)你完全不必考慮圖片的大小對頁面初始加載時(shí)間的影響,如果你不會(huì)調(diào)用圖片的話(前面說了,JS無法訪問未知加載內(nèi)容)。
但事實(shí)上,我們更需要一種方法,讓JS在瀏覽器獲得內(nèi)容后、真正展示在屏幕上前就開始執(zhí)行。
比較幸運(yùn)(也可能是不幸)的是,jQuery實(shí)現(xiàn)了這個(gè)方法:
$(document).ready(function(){
//...
})
不過據(jù)說jQuery的ready和原生JS的DOMContentLoaded效果是一樣的:網(wǎng)頁中所有DOM結(jié)構(gòu)繪制完畢后就執(zhí)行(可能DOM元素關(guān)聯(lián)的內(nèi)容并沒有加載完)
除此之外,JS中的window.onload和jQuery中的$(window).load()是等價(jià)的
哦,這里并不是盲目推崇jQuery,你完全可以去自己封裝一個(gè)。比如jQuery的ready()和JS的DOMContentLoaded實(shí)際上都實(shí)現(xiàn)了(或基于)這樣一段代碼:
functioninit(){
if(arguments.callee.done)return;
arguments.callee.done=true;
if(timer)clearInterval(timer);
//...
//判斷瀏覽器
//針對Mozilla/Opera9
if(document.addEventListener){
document.addEventListener('DOMContentLoaded',init,false)
//針對IE
document.write("scriptid='__ie_onloaddefer'src='javascript:void(O);'\/script
varscript=document.getElementById("__ie_onload");
script.onreadystatechange=function(){
if(this.readyState=="complete"){
init()//調(diào)用加截處理器
//針對Safari
if(/WebKit/i.test(navigator.userAgent)){
vartimer=setinterval(function(){
if(/loade
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026年智能停車輔助系統(tǒng)項(xiàng)目公司成立分析報(bào)告
- 2025年中職水利水電工程施工(水工建筑物基礎(chǔ))試題及答案
- 2026年家政服務(wù)教學(xué)(家政服務(wù)應(yīng)用)試題及答案
- 2025年高職防災(zāi)減災(zāi)技術(shù)(災(zāi)害預(yù)防措施)試題及答案
- 2025年高職物理學(xué)(相對論)試題及答案
- 2025年中職作曲與作曲技術(shù)理論(作曲理論)試題及答案
- 2025年中職(茶葉生產(chǎn)與加工)茶葉采摘標(biāo)準(zhǔn)試題及答案
- 2025年大學(xué)大四(印刷企業(yè)管理)企業(yè)運(yùn)營專項(xiàng)測試題及答案
- 2025年大學(xué)生態(tài)環(huán)境保護(hù)(生態(tài)修復(fù)工程)試題及答案
- 2025年高職數(shù)字媒體藝術(shù)設(shè)計(jì)(數(shù)字插畫創(chuàng)作)試題及答案
- 手術(shù)室查對制度
- 支氣管哮喘患者的自我管理宣教
- 第三次全國國土調(diào)查工作分類與三大類對照表
- 質(zhì)量效應(yīng)2楷模路線文字版
- 消防設(shè)施檢查記錄表
- 酒店協(xié)議價(jià)合同
- 哈爾濱工業(yè)大學(xué)簡介宣傳介紹
- 青光眼的藥物治療演示
- 羅永浩海淀劇場演講
- 蘇州市公務(wù)員考核實(shí)施細(xì)則
- GB/T 2703-2017鞋類術(shù)語
評論
0/150
提交評論