摘要:我們先下載官網(wǎng)地址比較兩者加載的區(qū)別傳統(tǒng)的加載方式采用加載我們可以看到,使用的方式代碼上顯示比較簡潔。幾個簡單的案例三個文件之間不存在依賴,異步加載為加載的文件指定類型它還有很多更好玩的用法,大家可以到官網(wǎng)上研究一番。
看到LABjs的時候是因為當(dāng)初希望實現(xiàn)js的異步加載,因為項目的歷史原因,在頁面中需要引用大量的js文件,為了優(yōu)化頁面的加載速度,做了不少的處理,在使用LABjs的過程中發(fā)現(xiàn)這插件真的很棒,原本頁面的初始加載時間需要4S左右的,在使用LABjs后,頁面的加載速度只需要2S-2.3S之間就完成了,它編寫簡單明了,當(dāng)然也有其他工具可以達(dá)到與它一樣的效果,在此不作比較,希望大家能夠喜歡這款插件(它僅僅只有6kb)。
我們先下載LABjs
比較兩者加載的區(qū)別官網(wǎng)地址"http://labjs.com/"
/** *傳統(tǒng)的JS加載方式 **/ /** *采用LABjs加載 **/
我們可以看到,使用LABjs的方式代碼上顯示比較簡潔。
幾個簡單的案例Example 1:
/** *三個js文件之間不存在依賴,異步加載 **/ $LAB .script("script1.js") .script("script2.js") .script("script3.js") .wait(function(){ // wait for all scripts to execute first script1Func(); script2Func(); script3Func(); });
Example 2:
/** *為加載的js文件指定類型 **/ $LAB .script({ src: "script1.js", type: "text/javascript" }) .script("script2.js") .script("script3.js") .wait(function(){ // wait for all scripts to execute first script1Func(); script2Func(); script3Func(); });
Example 3:
$LAB .script("script1.js", "script2.js", "script3.js") .wait(function(){ // wait for all scripts to execute first script1Func(); script2Func(); script3Func(); });
Example 4:
$LAB .script( [ "script1.js", "script2.js" ], "script3.js") .wait(function(){ // wait for all scripts to execute first script1Func(); script2Func(); script3Func(); });
Example 5:
$LAB .script("script1.js").wait() // empty wait() simply ensures execution order be preserved for this script .script("script2.js") // both script2 and script3 depend on script1 being executed before .script("script3.js").wait() // but are not dependent on each other and can execute in any order .script("script4.js") // depends on script1, script2 and script3 being loaded before .wait(function(){script4Func();});
Example 6:
$LAB .script("script1.js") // script1, script2, and script3 do not depend on each other, .script("script2.js") // so execute in any order .script("script3.js") .wait(function(){ // can still have executable wait(...) functions if you need to alert("Scripts 1-3 are loaded!"); }) .script("script4.js") // depends on script1, script2 and script3 being executed before .wait(function(){script4Func();});
它還有很多更好玩的用法,大家可以到官網(wǎng)上研究一番。趕緊試下它的效果,真的會給你帶來驚喜的。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/86010.html
摘要:加載的模塊會以參數(shù)形式傳入該函數(shù),從而在回調(diào)函數(shù)內(nèi)部就可以使用這些模塊。異步加載,和,瀏覽器不會失去響應(yīng)它指定的回調(diào)函數(shù),只有前面的模塊都加載成功后,才會運行,解決了依賴性的問題。插件,可以讓回調(diào)函數(shù)在頁面結(jié)構(gòu)加載完成后再運行。 這次主要是對《高性能JavaScript》一書的讀書筆記,記錄下自己之前沒有注意到或者需要引起重視的地方 第一章 加載和執(zhí)行 js代碼在執(zhí)行過程中會阻塞瀏覽...
摘要:參考精讀模塊化發(fā)展模塊化七日談前端模塊化開發(fā)那點歷史本文先發(fā)布于我的個人博客模塊化開發(fā)的演進(jìn)歷程,后續(xù)如有更新,可以查看原文。 Brendan Eich用了10天就創(chuàng)造了JavaScript,因為當(dāng)時的需求定位,導(dǎo)致了在設(shè)計之初,在語言層就不包含很多高級語言的特性,其中就包括模塊這個特性,但是經(jīng)過了這么多年的發(fā)展,如今對JavaScript的需求已經(jīng)遠(yuǎn)遠(yuǎn)超出了Brendan Eich的...
摘要:區(qū)別在于執(zhí)行時機,是加載完成后自動執(zhí)行,,而需要等待頁面完成后執(zhí)行。一旦新的元素被添加到文檔,代碼將會被執(zhí)行。這樣的好處是,可以下載但不是立即執(zhí)行代碼,還有一個好處是兼容性好。最好無論文件是以什么樣的方式加載的。 Javascript在瀏覽器性能中,這可能是所有開發(fā)者比較關(guān)注的問題,因為Javascript有阻塞的特征,也就是當(dāng)Javascript運行的時候,瀏覽器不會處理其他的任務(wù)。...
摘要:劇透一下,實現(xiàn)這個功能只需要行代碼。如何判斷文件已經(jīng)加載完畢可以在文件里執(zhí)行一個函數(shù),通知大家,我已經(jīng)加載完了。 唉?這種文章你也點進(jìn)來看,你不知道有 LABjs、RequireJS、SeaJS... 這些庫嗎? 反正我是沒用過這些庫,什么 AMD 、CMD 哪來那么多術(shù)語... 前端的庫太多了,要看各種亂七八糟的文檔,看文檔就想睡覺,就像學(xué)一門新語言一樣,好煩啊,還不如自己寫一個庫呢...
摘要:的堵塞特性上面引用兩段話的意思大致是,當(dāng)瀏覽器解析文檔時,一旦遇到標(biāo)簽沒有和屬性就會立即下載并執(zhí)行,與此同時瀏覽器對文檔的解析將會停止,直到代碼執(zhí)行完成。實現(xiàn)代碼執(zhí)行代碼缺點是不能跨域請求參考裝載和執(zhí)行元素所著的的第一章 Script 的堵塞(block)特性 Scripts without async or defer attributes, as well as inlin...
閱讀 982·2023-04-26 02:56
閱讀 9582·2021-11-23 09:51
閱讀 1889·2021-09-26 10:14
閱讀 2990·2019-08-29 13:09
閱讀 2161·2019-08-26 13:29
閱讀 578·2019-08-26 12:02
閱讀 3573·2019-08-26 10:42
閱讀 3012·2019-08-23 18:18