亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

js module大戰

2024-05-06 16:50:08
字體:
來源:轉載
供稿:網友

JS本身是一個多才多藝的語言,一個可以用自己編譯自己的自由度極高的語言。正因為這份自由,出現了天花亂墜的規范與框架們,其中最基礎的一塊便是Module。

來來來,baby們,做個小測試: CommonJS·AMD·CMD·UMD·ES6,這些模塊規范,大家熟悉幾個?

注意注意:本文乃筆者主觀寫出的歡快脫線認知,也許和真正的模塊形成的歷史有所區別。

一切的根源

JS是一個自由度極高的語言,即使沒有模塊的概念。也可以通過IIFE,new一個對象來實現類似與模塊的概念。也可以實現可復用,作用域獨立,易維護。這樣散裝的,無法維護各個模塊之間依賴。在一個JS文件中,模塊一多,也許就是修羅場。

Module的誕生

于是JS Module,一個令人又愛又恨的名詞誕生了。JS本身設計上就沒有模塊的概念,之后為了讓JS變成一個功能強大的語言,業界大佬們各顯神通,定了一個名為CommonJS的規范,實現了一個名為模塊的東西??上Т蠖酁g覽器并不支持,只能用于nodejs,于是CommonJS開始分裂,變異了一個名為AMD規范的模塊,可以用于瀏覽器端,而由于AMD與CommonJS規范相去甚遠,于是AMD自立門戶,并且推出了requireJS這個框架,用于實現并推廣AMD規范。正因為AMD與CommonJS如此不同,且用于不同的環境,為了能夠兼容兩個平臺,UMD應運而生,不過筆者認為僅僅是一個polyfill,以兼容兩個平臺。此時,CommonJS的擁護者認為,瀏覽端也可以實現CommonJS的規范,于是稍作改動,形成了CMD規范,并且推出了seajs這個框架。正在AMD與CMD打得火熱的時候,ECMAScript6給JS本身定了一個模塊加載的功能,ES6表示“你們也別爭了,JS模塊有原生的語法了”。

真正的規范

對于眾多規范中,只有CommonJS和ES6 import/export是真正的規范,其余的是利用JS現有的支持的方法模擬出的環境,以實現各自的規范。

至于為什么說CommonJS和ES6 import/export是真正的規范呢?因為只有原生支持他們的語法,才能實現他們的規范。

對于CommonJS而言,運行環境中,必須有require和module.exports的支持,才能運行。這就是瀏覽器與CommonJS無緣的主要原因。

至于ES6,失去對import和export關鍵字的支持,便一切都是零。比如,nodejs就不支持import和export,明明nodejs支持其他的ES6語法,怎么就對import和export如此不友好,筆者認為nodejs是為了實現commonJS的規范,因此不能接受ES6的模塊擾亂nodejs的模塊規范。

所以說CommonJS和ES6的模塊才是真正的規范。

關于CommonJS和ES6模塊,筆者曾經寫過一篇關于他們的文章,這里不多做贅述,移步至讀懂CommonJS的模塊加載。

有關瀏覽器實現CommonJS模塊的原理

既然瀏覽器缺少CommonJS的兩個關鍵字導致,模塊不成立,那么就創建一個模塊環境。使用define這個方法,將函數內部模擬成CommonJS的環境,提供require和module.export的方法。無論是seajs還是requirejs都是通過define模擬環境的辦法,實現module的。

自立門戶的AMD

筆者之前正在DIY臺式機,挑選顯卡的時候,在A卡和N卡之間猶豫了一下,之后果斷選A卡,因為A卡便宜一點。這里的A卡指的是AMD,那么和此處JS的AMD有社么關系嗎?沒有任何關系!只是因為JS模塊的AMD這個縮寫和人家美國的AMD公司的名字一致而已,這只是一個美麗的巧合。

AMD的全稱是Asynchronous Module Definition,中文名是異步模塊定義,不同于CommonJS的按需加載,也就是require了之后才加栽,AMD是將所有的潛在需要用到的包都加載運行了,也就是傳說中的高配,至于是否用得到就不再AMD的考慮范圍之內了。requirejs就是AMD的代表:

來自AMD的暴擊:

define("module1",function(require) { 'use strict'; console.log("cccc")});define("module2",function(require) { 'use strict'; console.log("aaaa") if(false){  console.log(require("module1")) } console.log("bbbb")});require(["module2"])

此時打印cccc,aaaa,bbbb,由此可見AMD是將所有的模塊,在模塊執行之前,就全部加載完畢了,所以AMD還有一種寫法是將所有的依賴模塊寫頭部。

define("module1",function(require) { 'use strict'; console.log("cccc")});define("module2",[module1],function(module1) { 'use strict'; console.log("aaaa") if(false){  console.log(require("module1")) } console.log("bbbb")});

瀏覽一下requirejs的源碼:

requirejs有兩種獲取依賴的方法,一種是配置,一種是利用正則匹配出所有的require的內容,然后加入依賴。當調用當前模塊的時候,就先檢查依賴的模塊是否運行了。

cjsRequireRegExp = /[^.]/s*require/s*/(/s*["']([^'"/s]+)["']/s*/)/g,

已經定義完成的模塊,會被緩存在一個對象之中,以模塊的名字為唯一健值,之后若再次調用此緩存的模塊,則無需再次執行。

執行之后緩存結果

defined[id] = exports;

二次執行,先檢查是否已存在,若存在怎不重復執行。

function callGetModule(args) { //Skip modules already defined. if (!hasProp(defined, args[0])) {  getModule(makeModuleMap(args[0], null, true)).init(args[1], args[2]); }}

若是遠程依賴,則創建一個script,加載遠程資源,并將script加入頭部。

req.createNode = function (config, moduleName, url) { var node = config.xhtml ?   document.createElementNS('http://www.w3.org/1999/xhtml', 'html:script') :   document.createElement('script'); node.type = config.scriptType || 'text/javascript'; node.charset = 'utf-8'; node.async = true; return node;};

那么UMD是個什么樣的存在

第一次接觸到UMD,是在webpack的打包之中,想要生成一個library,有好多個選項,CommonJS,amd,umd。當時一下子有點懵,UMD是什么?在不知情的情況下,又出現了一個模塊規范,這讓筆者的頭很大啊。

來自webpack的凝視:

output: { path: path.join(__dirname), filename: 'index.js', libraryTarget: "umd",//此處是希望打包的插件類型 library: "Swiper",}

看一眼打包后的效果:

!function(root,callback){"object"==typeof exports&&"object"==typeof module?//判斷是不是nodejs環境 module.exports=callback(require("react"),require("prop-types")) : "function"==typeof define&&define.amd?//判斷是不是requirejs的AMD環境  define("Swiper",["react","prop-types"],callback)  :"object"==typeof exports?//相當于連接到module.exports.Swiper   exports.Swiper=callback(require("react"),require("prop-types"))   :   root.Swiper=callback(root.React,root.PropTypes)//全局變量}(window,callback)

這樣一個polyfill,瞬間就兼容了CommonJS,AMD和全局的一個模塊。這就是UMD,比起規范,不如說它是一個兼容,polyfill,支持多個模塊規范。

where is CMD?

眼尖的小伙伴應該發現了,CMD不知去向,webpack的打包中也沒有CMD模塊的一個選項。CMD其實就是按照CommonJS規范,然后進行改造,從而使之支持瀏覽器端的一種規范。

主要說說他和AMD的主要區別吧:

require關鍵字引入內容的執行順序。AMD是一個依賴提前加載的概念,而CMD是同步執行,遇到require之后再執行當前的一個模塊。

define("c",function(require, exports, module) { console.log("bbb")});define("b",function(require, exports, module) { console.log("aaa") require("c") console.log("ccc")});seajs.use("b")

這樣打印的就是 aaa,bbb,ccc。按照代碼出現的順序執行。

當然這個是同步代碼的區別,至于異步代碼,CMD和AMD都是通過script,append到head加載,存入模塊對象之中,然后根據id調用。不過CMD有一點不同,加了一個小小的優化:

if (!data.debug) { head.removeChild(node)}

當代碼加載完畢之后,并且緩存在模塊之中之后,便在head之中刪除了這個script。

后記

借用魯迅的一句話“世上本沒有路,走的人多了也就成了路”。JS MODUDLE的規范也是如此,用的人多了也就是默認的解決方案了。

JS MODULE大戰就寫到這邊吧,大家都不曉得這些模塊的規范能夠存活多久,但是概念都很好。所以好好學習概念,以后就算有新的規范出來了,和老規范一對比,找出不同點,加以分析,便能夠輕松上手!

參考地址

不能忘記幫助筆者認知模塊的文章們,謝謝大佬們:

requirejs:requirejs的官網對于AMD產生歷史的解釋。
前端模塊化開發那點歷史 :seajs的大佬對模塊這一塊的看法,梳理了筆者對于AMD的困惑
overflow上對于AMD和requirejs的一個解釋

以上所述是小編給大家介紹的js module詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久久久激情视频| 欧美福利视频在线| 精品久久久久久久中文字幕| 国产精品视频资源| 亚洲欧美制服中文字幕| 国产一区二区三区在线| 亚洲偷欧美偷国内偷| 国产欧美日韩中文字幕| 日韩精品在线免费播放| 日韩欧美中文字幕在线观看| 成人免费大片黄在线播放| 日本久久久久久久久久久| 欧美大尺度激情区在线播放| 亚洲男人天堂2023| 欧美性xxxx18| 97视频在线观看网址| 精品视频中文字幕| 视频在线一区二区| 国产欧美一区二区三区久久| 欧美成人精品在线观看| 日韩不卡在线观看| 久久久精品一区| 精品偷拍一区二区三区在线看| 国产精品第8页| 国产一区深夜福利| 色999日韩欧美国产| 91青草视频久久| 日韩精品有码在线观看| 日韩精品在线视频观看| 久久久久免费视频| 欧美日韩一区免费| 欧美激情在线有限公司| 国产精品久久久久久久久男| 精品成人av一区| 在线视频免费一区二区| 狠狠躁天天躁日日躁欧美| 亚洲一区二区三区视频播放| 国产精品美女免费看| 97人洗澡人人免费公开视频碰碰碰| 91精品国产高清自在线看超| 欧美性猛交xxxxx水多| 国产噜噜噜噜噜久久久久久久久| 亚洲成色777777在线观看影院| 日韩综合中文字幕| 日韩高清电影好看的电视剧电影| 国产一区二区色| 日韩免费电影在线观看| 精品色蜜蜜精品视频在线观看| 色综合伊人色综合网| 欧美丰满片xxx777| 成人字幕网zmw| 欧洲成人在线视频| 国产精品久久久久久久久久东京| 高清一区二区三区日本久| 国产精品视频免费在线观看| 日韩电影免费观看中文字幕| 国产日韩亚洲欧美| 久久久久日韩精品久久久男男| 亚洲全黄一级网站| 欧美成人性色生活仑片| 欧美日韩在线视频观看| 亚洲第一级黄色片| 精品在线欧美视频| 欧美日韩另类在线| 45www国产精品网站| 日韩精品在线播放| 欧美性猛交xxxx乱大交蜜桃| 精品色蜜蜜精品视频在线观看| 欧美性猛交xxxxx免费看| 97碰碰碰免费色视频| 日韩美女福利视频| 欧美午夜宅男影院在线观看| 亚洲成人教育av| 国产欧美日韩亚洲精品| 欧美激情综合色综合啪啪五月| 国自产精品手机在线观看视频| 国产一区二区久久精品| 日韩电影免费在线观看中文字幕| 国产日韩欧美在线观看| 国产99视频精品免视看7| 韩国国内大量揄拍精品视频| 日韩电视剧免费观看网站| 国产精品久久久久久一区二区| 国产主播精品在线| 日韩精品在线免费观看| 国产成人亚洲综合91| 日韩美女免费线视频| 久久精品久久精品亚洲人| 91精品久久久久| 不卡毛片在线看| 伊人成人开心激情综合网| 97热在线精品视频在线观看| 国产视频精品xxxx| 91精品成人久久| 亚洲精品欧美一区二区三区| 国产成人精品亚洲精品| 高清欧美性猛交xxxx| 欧美大胆a视频| 亚洲一级片在线看| 91免费高清视频| 欧美xxxwww| 欧美在线视频播放| 欧美大尺度在线观看| 欧美激情va永久在线播放| 国产精品成人一区二区| 91在线直播亚洲| 午夜精品一区二区三区av| 日韩在线视频免费观看高清中文| 亚洲第一天堂av| 欧美性猛交xxxxx水多| 亚洲免费人成在线视频观看| 亚洲字幕在线观看| 亚洲欧美三级伦理| 国产+人+亚洲| 国产精品久久久久久网站| 日韩欧美国产网站| 亚洲日本欧美日韩高观看| 一区二区亚洲精品国产| 色综合色综合网色综合| 一区二区亚洲欧洲国产日韩| 精品视频偷偷看在线观看| 中文字幕亚洲激情| 亚洲精品第一国产综合精品| 欧美最近摘花xxxx摘花| 久久久久久一区二区三区| 欧美色道久久88综合亚洲精品| 国产欧美一区二区白浆黑人| 日韩在线免费视频| 日韩免费电影在线观看| 国产成人精品久久亚洲高清不卡| 亚洲国产精品久久久久久| 国产极品精品在线观看| 日韩精品免费在线视频| 91亚洲国产成人久久精品网站| 精品久久久久久久久久久久久久| 伊人久久五月天| 国产精品久久久久久久久久小说| 亚洲国产欧美久久| 久久久免费在线观看| 中文字幕一精品亚洲无线一区| 亚洲一区二区免费| 一区二区欧美在线| 亚洲精品天天看| 成人免费xxxxx在线观看| 国产精品中文字幕久久久| xxx成人少妇69| 色综合男人天堂| 欧美成人在线影院| 欧美华人在线视频| 欧美极品美女电影一区| 91性高湖久久久久久久久_久久99| 91社区国产高清| 欧美在线国产精品| 亚洲欧美国产日韩天堂区| 日本不卡视频在线播放| 国产亚洲精品美女久久久| 亚洲天天在线日亚洲洲精| 欧美一区三区三区高中清蜜桃| 国产免费久久av| 亚洲福利视频在线| 亚洲人成伊人成综合网久久久| 久久精品国产久精国产一老狼| 久久综合网hezyo| 7m精品福利视频导航|