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

資訊專欄INFORMATION COLUMN

關于CommonJS、AMD、CMD、UMD說明

harryhappy / 1817人閱讀

摘要:函數(shù)有兩個參數(shù),第一個參數(shù)是當前運行時環(huán)境,第二個參數(shù)是模塊的定義體。在執(zhí)行規(guī)范時,會優(yōu)先判斷是當前環(huán)境是否支持環(huán)境,然后再檢驗是否支持環(huán)境,否則認為當前環(huán)境為瀏覽器環(huán)境

CommonJS規(guī)范

CommonJS定義的模塊分為3部分:

require 模塊引用

exports 模塊導出

module 模塊本身

根據(jù)CommonJS規(guī)范,一個多帶帶的文件就是一個模塊。每一個模塊都是一個多帶帶的作用域,也就是說,在一個文件定義的變量(還包括函數(shù)和類),都是私有的,對其他文件是不可見的

// a.js

var a = {
    "a":a,
    "b":b
}

module.export = a //模塊導出

// b.js
var b = require("./a.js") //模塊引入

CommonJS 加載模塊是同步的,所以只有加載完成才能執(zhí)行后面的操作

AMD(Asynchromous Module Definition)規(guī)范

AMD 加載模塊是異步

define(id?, dependencies?, factory);

id: 模塊標識,可以省略。
dependencies: 所依賴的模塊,可以省略。
factory: 模塊的實現(xiàn),或者一個JavaScript對象。    

   //a.js 只有factory
   define(function() {
       return {
           mix: function(source, target) {
               ...
            }
        };
    });
    
    //b.js 依賴a.js
    define(["a"], function(a) {
        return {
            show: function() {
               ...
            }
        }
    });
    
    //c.js 依賴a.js b.js
    define(["a", "b"], function(a, b) {
        ....
    });
    
    //d.js 對象模塊
    define({
        data1: [],
        data2: []
    });

AMD規(guī)范允許輸出模塊兼容CommonJS規(guī)范,這時define方法如下:

    define(function (require, exports, module) {
        var reqModule = require("./a.js");
        requModule.mix();
        
        exports.asplode = function () {
            ...
        }
    });
CMD(Common Module Definition)規(guī)范

CMD和AMD的區(qū)別有以下幾點:

對于依賴的模塊AMD是提前執(zhí)行,CMD是延遲執(zhí)行。不過RequireJS從2.0開始,也改成可以延遲執(zhí)行(根據(jù)寫法不同,處理方式不通過)

CMD推崇依賴就近,AMD推崇依賴前置

    //AMD寫法
    define(["./a","./b"], function (a, b) {
        //依賴一開始就寫好
        a.mix();
        b.show();
    });
    
    //CMD寫法
    define(function (requie, exports, module) {
        //依賴可以就近書寫
        var a = require("./a");
        a.mix();
        
        if (...) {
            var b = requie("./b");
            b.show();
        }
    });
UMD(Universal Module Definition)規(guī)范
(function (root, factory) {
    if (typeof define === "function" && define.amd) {
        // AMD
        define(["jquery"], factory);
    } else if (typeof exports === "object") {
        // Node, CommonJS-like
        module.exports = factory(require("jquery"));
    } else {
        // Browser globals (root is window)
        root.returnExports = factory(root.jQuery);
    }
}(this, function ($) {
    //    methods
    function myFunc(){};

    //    exposed public method
    return myFunc;
}));

應用UMD規(guī)范的js文件其實就是一個立即執(zhí)行函數(shù)。函數(shù)有兩個參數(shù),第一個參數(shù)是當前運行時環(huán)境,第二個參數(shù)是模塊的定義體。在執(zhí)行UMD規(guī)范時,會優(yōu)先判斷是當前環(huán)境是否支持AMD環(huán)境,然后再檢驗是否支持CommonJS環(huán)境,否則認為當前環(huán)境為瀏覽器環(huán)境( window

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

轉載請注明本文地址:http://systransis.cn/yun/80061.html

相關文章

  • AMD, CMD, CommonJSUMD

    摘要:若不存在則模塊標識應該默認定義為在加載器中被請求腳本的標識。其中是一個數(shù)組,里面的成員就是要加載的模塊是模塊加載完成之后的回調(diào)函數(shù)。在加載與兩個模塊之后執(zhí)行回調(diào)函數(shù)實現(xiàn)具體過程。在判斷是否支持是否存在,存在則使用方式加載模塊。 我的github(PS:希望star): https://github.com/tonyzheng1... 今天由于項目中引入的echarts的文件太大,req...

    KavenFan 評論0 收藏0
  • JS常見模塊化規(guī)范(CommonJS/AMD/CMD/UMD/ES6 Module)

    摘要:常見模塊化方案是由社區(qū)提出的模塊化方案中的一種,遵循了這套方案。是模塊化規(guī)范中的一種,遵循了這套規(guī)范。中的模塊化能力由兩個命令構成和,命令用于規(guī)定模塊的對外接口,命令用于輸入其他模塊提供的功能。 為什么需要模塊化 在ES6出現(xiàn)之前,JS語言本身并沒有提供模塊化能力,這為開發(fā)帶來了一些問題,其中最重要的兩個問題應當是全局污染和依賴管理混亂。 // file a.js var name =...

    walterrwu 評論0 收藏0
  • JS模塊化——CommonJS AMD CMD UMD ES6 Module 比較

    摘要:即盡早地執(zhí)行依賴模塊。阮一峰輸出值的引用模塊是動態(tài)關聯(lián)模塊中的值,輸出的是值得引用。的加載實現(xiàn)阮一峰運行時加載靜態(tài)編譯模塊是運行時加載,模塊是編譯時輸出接口。 模塊化開發(fā) 優(yōu)點 模塊化開發(fā)中,通常一個文件就是一個模塊,有自己的作用域,只向外暴露特定的變量和函數(shù),并且可以按需加載。 依賴自動加載,按需加載。 提高代碼復用率,方便進行代碼的管理,使得代碼管理更加清晰、規(guī)范。 減少了命名沖...

    shadowbook 評論0 收藏0
  • js中的模塊化——commonjs,AMD,CMD,UMD,ES6

    摘要:若不存在則模塊標識應該默認定義為在加載器中被請求腳本的標識。這也是目前很多插件頭部的寫法,就是用來兼容各種不同模塊化的寫法。語句輸出的值是動態(tài)綁定的,綁定其所在的模塊。 前言 歷史上,js沒有模塊化的概念,不能把一個大工程分解成很多小模塊。這對于多人開發(fā)大型,復雜的項目形成了巨大的障礙,明顯降低了開發(fā)效率,java,Python有import,甚至連css都有@import,但是令人費...

    qpal 評論0 收藏0
  • JS模塊規(guī)范:AMD、UMDCMD、commonJS、ES6 module

    摘要:要想讓模塊再次運行,必須清除緩存。模塊加載會阻塞接下來代碼的執(zhí)行,需要等到模塊加載完成才能繼續(xù)執(zhí)行同步加載。環(huán)境服務器環(huán)境應用的模塊規(guī)范是參照實現(xiàn)的。這等同在每個模塊頭部,有一行這樣的命令。 commonJS 特點: 1、模塊可以多次加載,但是只會在第一次加載時運行一次,然后運行結果就被緩存了,以后再加載,就直接讀取緩存結果。要想讓模塊再次運行,必須清除緩存。2、模塊加載會阻塞接下來代...

    _ang 評論0 收藏0

發(fā)表評論

0條評論

harryhappy

|高級講師

TA的文章

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