国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

腳本安需導(dǎo)入(裝載)的三種模式的對比

2019-11-21 02:02:07
字體:
供稿:網(wǎng)友
何謂安需裝載?
    腳本程序一般都是下載后執(zhí)行,當腳本庫非常龐大時,一次性下載起來非常費時,傳統(tǒng)的解決方式是,按功能模塊把腳本寫在不同的文件中,頁面上手動加入 script標簽裝載指定內(nèi)容,但是這有一些缺點,類庫的使用者需要知道沒個腳本之間的關(guān)系,順序要求等等,而不可能要求每個類庫使用者都對其非常熟悉,出錯的可能性很大。于是很多框架開始支持導(dǎo)入指令,想使用什么一個導(dǎo)入函數(shù)就完了,不必一堆堆的script文件,不用小心翼翼的關(guān)注著他們的依賴關(guān)系。

安需裝載的困境:
      早期安需裝載(即時同步按需裝載)有一個致命的弱點,瀏覽器阻塞問題。當按需裝載某些類庫時,通常通過XMLHttpRequest同步裝載腳本文件實現(xiàn),這種情況下,在資源下載完成之前,瀏覽器將停止響應(yīng)用戶事件、停止頁面重畫操作。如果網(wǎng)速很慢,這段時間將非常讓人討厭,就像是死機似的。

      以前的解決辦法是,將常用類庫資源直接打包到框架文件中,而按需導(dǎo)入就成了一個宣傳的幌子,沒有太多實際的價值。

安需裝載可分如下三種模式:


l 即時同步按需裝載 (阻塞,JSI、JSVM、dojo)。

最簡單的按需裝載實現(xiàn),通過XMLHttpRequest同步裝載腳本文件實現(xiàn)。問題是,瀏覽器使用這種方式同步獲取資源時將導(dǎo)致瀏覽器阻塞:停止響應(yīng)用戶事件、停止頁面重畫操作。所以,雖然編程最為簡單,但是用戶體驗最差。

 

2 異步按需裝載(無阻塞,JSI2.0+)。

異步導(dǎo)入,不必多做解釋,用戶體驗好,但是因為其異步特征,處理起來比較麻煩。

 

3 延遲同步按需裝載(無阻塞,JSI2.0+)。

JSI通過動態(tài)預(yù)裝載功能實現(xiàn)的一種同步獲取資源的方法,雖然也是同步,但沒有阻塞,可以算時兼顧易用性和用戶體驗的解決方按。缺點時有一定延遲,當前腳本標簽中不可用。

       

 

使用方法(JSI示例)
    以一個代碼語法著色程序為例:

類庫位置:org/xidea/example/code/code.js

頁面位置:example/xxx.html

 

即時同步按需裝載

import("org.xidea.example.code.Code"); 

var code1 = new Code(); 

code1.id = "libCode"; 

code1.decorate();

 


異步按需裝載

$import("org.xidea.example.code.Code",function(Code){        

var code1 = new Code();        

code1.id = "libCode";        

code1.decorate();  

})    




延遲同步按需裝載(無阻塞,JSI2.0+)。

<script>"../scripts/boot.js"></script>    

<script>    

$import("org.xidea.example.code.Code",true);    

</script>    

    

<script>    

var code1 = new Code();    

code1.id = "pageCode";    

code1.decorate();    

</script>    




測試示例: 
地址:

http://jsintegration.sourceforge.net/example/code.html

http://www.xidea.org/project/jsi/example/code.html 

    示例都是jsi的默認示例,可以下載到本地運行,下載后最好能放到一個能受到網(wǎng)速限制的服務(wù)器上,只有這樣才能看到阻塞的問題。

參考:
JSI 導(dǎo)入函數(shù): function $import(path, callbackOrLazyLoad, target ) 

 

JSI2 預(yù)覽版下載:http://groups.google.com/group/jsier/files

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 东安县| 青岛市| 会同县| 临湘市| 博白县| 扬中市| 乌鲁木齐县| 武定县| 久治县| 侯马市| 慈溪市| 枞阳县| 长宁县| 盐山县| 项城市| 灵武市| 本溪| 镇江市| 卢氏县| 镶黄旗| 阳山县| 库车县| 志丹县| 平江县| 萝北县| 武冈市| 赫章县| 桃园县| 香港 | 汉源县| 成安县| 敦化市| 嘉善县| 昆山市| 宁晋县| 深泽县| 太湖县| 酒泉市| 淅川县| 民勤县| 彭州市|