国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專(zhuān)欄INFORMATION COLUMN

切圖崽的自我修養(yǎng)-使用模塊化JS

littleGrow / 774人閱讀

摘要:之前的閉包也好,自執(zhí)行函數(shù)也好,都是模塊化的一些嘗試,直到規(guī)范推出之后,模塊化才真正迅猛發(fā)展起來(lái)。因?yàn)橛辛四K化的概念,才有了按需加載的概念。

前言

我們來(lái)玩樂(lè)高積木吧

模塊化Js已經(jīng)成為了老生常談,不過(guò)在JavaScript設(shè)計(jì)之初,由于定位的問(wèn)題并沒(méi)有提供類(lèi)的功能,開(kāi)發(fā)者需要模擬出類(lèi)似的功能,來(lái)隔離、組織復(fù)雜的JavaScript代碼。之前的閉包也好,自執(zhí)行函數(shù)也好,都是模塊化的一些嘗試,直到CommonJs規(guī)范推出之后,模塊化Js才真正迅猛發(fā)展起來(lái)。

從時(shí)間點(diǎn)上來(lái)說(shuō):

Node遵循CommonJs模塊化規(guī)范,NPM包管理系統(tǒng)發(fā)展如此迅猛就是CommonJs模塊化規(guī)范的最佳實(shí)踐

后來(lái)在CommonJs的基礎(chǔ)上衍生出了AMD/CMD規(guī)范,其各自的實(shí)踐分別是RequireJSSeaJs

CommonJs同步加載規(guī)范

CommonJs規(guī)范遵循的是同步加載模塊規(guī)范,即:

var A = require(./module/a);
A.funA();
var B = require(./module/b);
B.funB();

即只有a.js加載完以后,才能接著向下執(zhí)行A.funA();才能接著向下加載b.js, 等b.js加載完之后,才能向下執(zhí)行B.funB();。但這種同步串行的加載方式確對(duì)效率并沒(méi)有多大影響,因?yàn)?b>CommonJs是在Node上運(yùn)行,處于服務(wù)器環(huán)境,服務(wù)器環(huán)境對(duì)模塊的加載等同于硬盤(pán)的讀寫(xiě)速度,是非常非常快的。

AMD/CMD異步加載規(guī)范

AMD/CMD 遵循的是異步加載模塊規(guī)范,拿CMD規(guī)范的SeaJs舉例:

 define(function(require,exports,module){
    require.async("./module/a", function(){alert(1)}
    require.async("./module/b", function(){alert(2)}
  });

其中,alert(1) 和alert(2)的執(zhí)行順序是不固定的,因?yàn)槭遣捎卯惒郊虞d模塊的方式,a模塊和b模塊是并行加載的 ,誰(shuí)先加載完畢,誰(shuí)先掉用回調(diào). 因?yàn)榫W(wǎng)絡(luò)和文件大小的原因, 當(dāng)然有可能是b模塊先加載完畢,所以可能是alert(2)先執(zhí)行.

因?yàn)?b>requireJs(AMD)和SeaJs(CMD) 都是運(yùn)行在客戶端瀏覽器上的. 模塊的加載速度和網(wǎng)絡(luò)狀況有關(guān)系,加載情況是非常不穩(wěn)定,如果采用同步串行加載的方式,會(huì)出現(xiàn)因?yàn)榍懊娴哪K加載耗時(shí)太長(zhǎng)而阻塞了它之后的模塊的加載. 所以AMD/CMD才有了異步的解決方案

(當(dāng)然,AMD/CMD也支持同步加載)

按需加載

按需加載是模塊化Js引伸出來(lái)的概念.我們可以讓特定的頁(yè)面加載特定的JS,就像搭積木剛好把房子搭起來(lái)一樣,用Js模塊組合的方式可以項(xiàng)目搭建起來(lái),保證不缺少任何一個(gè)必要的模塊,也保證不會(huì)有任何一個(gè)多余的模塊.

如果index.html只需要彈窗功能和滑動(dòng)功能,就只加載pop.js和slip.js

說(shuō)起來(lái)倒是挺簡(jiǎn)單,但實(shí)際上呢?

實(shí)際上也非常簡(jiǎn)單,拿seaJS舉例來(lái)說(shuō),頁(yè)面index.html引用了Sea.js后,就可以以index.js為加載入口,對(duì)頁(yè)面所需的七七八八的JS模塊進(jìn)行加載:

index.html:




其中index.js:

define(function(require,exports,module){
     //引入模塊a
     var A = require("./module/a"); 
     //引入模塊b
     var B = require("./module/b")     
     
     ...
});

其中a.js又依賴了其他的模塊:

define(function(require,exports,module){
     //引入模塊c
     var C = require("./module/c");          
     ...
});    

不管這個(gè)依賴關(guān)系有多復(fù)雜,層級(jí)有多深,seaJS的模塊加載器會(huì)遞歸找到所有頁(yè)面index.html依賴的Js,就拿例子來(lái)說(shuō),和index.html有關(guān)的依賴有 入口文件index.js和它依賴的a.js, b.js ,并且還有a.js依賴的 c.js 所以最后index.html實(shí)際上會(huì)加載index.js, a.js, b.js , c.js

這樣就實(shí)現(xiàn)了頁(yè)面需要什么模塊,就加載什么模塊(和這些模塊依賴的模塊),從而實(shí)現(xiàn)了按需加載。

但有同學(xué)估計(jì)又想到了,這個(gè)地方有個(gè)小缺陷,雖然模塊化Js使得加載邏輯更清晰了,但是如此碎片化的Js會(huì)增加頁(yè)面http的請(qǐng)求數(shù),從而影響頁(yè)面的加載速度。

沒(méi)錯(cuò),所以我們通常在上線前會(huì)利用自動(dòng)化工具對(duì)當(dāng)前頁(yè)面依賴的所有Js做一個(gè)合并處理,即合并壓縮成一個(gè)Js文件, 這樣能最大程度上的利用瀏覽器緩存,減少Http請(qǐng)求數(shù)。

(注:Js模塊書(shū)寫(xiě)的時(shí)候請(qǐng)盡量避免循環(huán)引用的問(wèn)題,即a.js引用了c.js,反過(guò)來(lái)c.js又引用了a.js. 這肯定是模塊書(shū)寫(xiě)不規(guī)范造成的,請(qǐng)檢查這兩個(gè)模塊的邏輯是否有重疊. 當(dāng)然,除此之外循環(huán)引用還是有別的辦法解決的,這里就不提了)

結(jié)語(yǔ)

總而言之,模塊化Js目前有兩大規(guī)范(當(dāng)然要說(shuō)成三種規(guī)范也可以,不過(guò)在作者本人看來(lái)AMD/CMD并沒(méi)有本質(zhì)上的區(qū)別)

CommonJS同步加載模塊規(guī)范,運(yùn)行在服務(wù)端

AMD/CMD 異步加載模塊規(guī)范,運(yùn)行在客戶端

因?yàn)镃ommonJs規(guī)范在服務(wù)器端的同步串行加載Js模塊的方式并不適用于客戶端瀏覽器,所以才有了AMD/CMD規(guī)范延伸出異步并行加載Js模塊的方式。

因?yàn)橛辛薐s模塊化的概念,才有了Js按需加載的概念。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/79906.html

相關(guān)文章

  • 切圖崽的自我修養(yǎng)使用自動(dòng)化工具

    摘要:前言已爛想來(lái)大家對(duì)自動(dòng)化構(gòu)建工具已經(jīng)不陌生了,自動(dòng)化構(gòu)建工具可以幫開(kāi)發(fā)者省去很多重復(fù)勞動(dòng)比如語(yǔ)法糾錯(cuò)文件打包文件操作,合并壓縮等等常用的自動(dòng)化構(gòu)建工具有等等,這些構(gòu)建工具核心都是依賴第三方插件,通過(guò)顆粒化任務(wù),再將這些任務(wù)按照合適的方式進(jìn)行 前言 F5已爛 showImg(https://segmentfault.com/img/bVyS47); 想來(lái)大家對(duì)自動(dòng)化構(gòu)建工具已經(jīng)不陌生了,...

    jayce 評(píng)論0 收藏0
  • 切圖崽的自我修養(yǎng)使用自動(dòng)化工具

    摘要:前言已爛想來(lái)大家對(duì)自動(dòng)化構(gòu)建工具已經(jīng)不陌生了,自動(dòng)化構(gòu)建工具可以幫開(kāi)發(fā)者省去很多重復(fù)勞動(dòng)比如語(yǔ)法糾錯(cuò)文件打包文件操作,合并壓縮等等常用的自動(dòng)化構(gòu)建工具有等等,這些構(gòu)建工具核心都是依賴第三方插件,通過(guò)顆粒化任務(wù),再將這些任務(wù)按照合適的方式進(jìn)行 前言 F5已爛 showImg(https://segmentfault.com/img/bVyS47); 想來(lái)大家對(duì)自動(dòng)化構(gòu)建工具已經(jīng)不陌生了,...

    GT 評(píng)論0 收藏0
  • 切圖崽的自我修養(yǎng)使用自動(dòng)化工具

    摘要:前言已爛想來(lái)大家對(duì)自動(dòng)化構(gòu)建工具已經(jīng)不陌生了,自動(dòng)化構(gòu)建工具可以幫開(kāi)發(fā)者省去很多重復(fù)勞動(dòng)比如語(yǔ)法糾錯(cuò)文件打包文件操作,合并壓縮等等常用的自動(dòng)化構(gòu)建工具有等等,這些構(gòu)建工具核心都是依賴第三方插件,通過(guò)顆粒化任務(wù),再將這些任務(wù)按照合適的方式進(jìn)行 前言 F5已爛 showImg(https://segmentfault.com/img/bVyS47); 想來(lái)大家對(duì)自動(dòng)化構(gòu)建工具已經(jīng)不陌生了,...

    luqiuwen 評(píng)論0 收藏0
  • 切圖崽的自我修養(yǎng)-[ES6] 編程風(fēng)格規(guī)范

    摘要:前言沒(méi)有規(guī)矩不成方圓用替換來(lái)定義變量如果是常量,使用靜態(tài)字符串統(tǒng)一用單引號(hào)動(dòng)態(tài)拼接成的字符串統(tǒng)一用反引號(hào)使用數(shù)組成員對(duì)變量賦值時(shí),盡量用解構(gòu)賦值往對(duì)象里添加修改屬性時(shí),使用,而不用松散的語(yǔ)法面向?qū)ο蟮膶?xiě)法一律寫(xiě)成的形式,摒棄原生的的書(shū)寫(xiě)方法 前言 沒(méi)有規(guī)矩 不成方圓 用let替換var來(lái)定義變量. 如果是常量,使用const 靜態(tài)字符串統(tǒng)一用單引號(hào) , 動(dòng)態(tài)拼接成的字符串統(tǒng)一用反...

    Bryan 評(píng)論0 收藏0
  • 切圖崽的自我修養(yǎng)-[ES6] 編程風(fēng)格規(guī)范

    摘要:前言沒(méi)有規(guī)矩不成方圓用替換來(lái)定義變量如果是常量,使用靜態(tài)字符串統(tǒng)一用單引號(hào)動(dòng)態(tài)拼接成的字符串統(tǒng)一用反引號(hào)使用數(shù)組成員對(duì)變量賦值時(shí),盡量用解構(gòu)賦值往對(duì)象里添加修改屬性時(shí),使用,而不用松散的語(yǔ)法面向?qū)ο蟮膶?xiě)法一律寫(xiě)成的形式,摒棄原生的的書(shū)寫(xiě)方法 前言 沒(méi)有規(guī)矩 不成方圓 用let替換var來(lái)定義變量. 如果是常量,使用const 靜態(tài)字符串統(tǒng)一用單引號(hào) , 動(dòng)態(tài)拼接成的字符串統(tǒng)一用反...

    DoINsiSt 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<