成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

LABJS的使用教程

dreamans / 2010人閱讀

摘要:我們先下載官網(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

官網(wǎng)地址"http://labjs.com/"

比較兩者加載的區(qū)別
/**
*傳統(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

相關(guān)文章

  • 《高性能JavaScript》(讀書筆記)

    摘要:加載的模塊會以參數(shù)形式傳入該函數(shù),從而在回調(diào)函數(shù)內(nèi)部就可以使用這些模塊。異步加載,和,瀏覽器不會失去響應(yīng)它指定的回調(diào)函數(shù),只有前面的模塊都加載成功后,才會運行,解決了依賴性的問題。插件,可以讓回調(diào)函數(shù)在頁面結(jié)構(gòu)加載完成后再運行。 這次主要是對《高性能JavaScript》一書的讀書筆記,記錄下自己之前沒有注意到或者需要引起重視的地方 第一章 加載和執(zhí)行 js代碼在執(zhí)行過程中會阻塞瀏覽...

    moven_j 評論0 收藏0
  • JavaScript模塊化開發(fā)演進(jìn)歷程

    摘要:參考精讀模塊化發(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的...

    anonymoussf 評論0 收藏0
  • Javascript加載執(zhí)行方法總結(jié)

    摘要:區(qū)別在于執(zhí)行時機,是加載完成后自動執(zhí)行,,而需要等待頁面完成后執(zhí)行。一旦新的元素被添加到文檔,代碼將會被執(zhí)行。這樣的好處是,可以下載但不是立即執(zhí)行代碼,還有一個好處是兼容性好。最好無論文件是以什么樣的方式加載的。 Javascript在瀏覽器性能中,這可能是所有開發(fā)者比較關(guān)注的問題,因為Javascript有阻塞的特征,也就是當(dāng)Javascript運行的時候,瀏覽器不會處理其他的任務(wù)。...

    Coding01 評論0 收藏0
  • 自制 require 函數(shù):讓瀏覽器輕松實現(xiàn) js 文件按需加載

    摘要:劇透一下,實現(xiàn)這個功能只需要行代碼。如何判斷文件已經(jīng)加載完畢可以在文件里執(zhí)行一個函數(shù),通知大家,我已經(jīng)加載完了。 唉?這種文章你也點進(jìn)來看,你不知道有 LABjs、RequireJS、SeaJS... 這些庫嗎? 反正我是沒用過這些庫,什么 AMD 、CMD 哪來那么多術(shù)語... 前端的庫太多了,要看各種亂七八糟的文檔,看文檔就想睡覺,就像學(xué)一門新語言一樣,好煩啊,還不如自己寫一個庫呢...

    qianfeng 評論0 收藏0
  • HTML中script標(biāo)簽研究

    摘要:的堵塞特性上面引用兩段話的意思大致是,當(dāng)瀏覽器解析文檔時,一旦遇到標(biāo)簽沒有和屬性就會立即下載并執(zhí)行,與此同時瀏覽器對文檔的解析將會停止,直到代碼執(zhí)行完成。實現(xiàn)代碼執(zhí)行代碼缺點是不能跨域請求參考裝載和執(zhí)行元素所著的的第一章 Script 的堵塞(block)特性 Scripts without async or defer attributes, as well as inlin...

    ernest.wang 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<