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

首頁 > 語言 > JavaScript > 正文

Javascript中的匿名函數與封裝介紹

2024-05-06 16:16:52
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Javascript中的匿名函數與封裝介紹,本文分析了jQuery 封裝、Backbone 封裝、Underscore 封裝等內容,需要的朋友可以參考下
 

迷惑了一會兒不同JS庫的封裝后,終于有了點頭緒。大致就是:

復制代碼代碼如下:

創建一個自調用匿名函數,設計參數window,并傳入window對象。

而這個過程的目的則是,
復制代碼代碼如下:

使得自身的代碼不會被其他代碼污染,同時也可以不污染其他代碼。

jQuery 封裝

 

于是找了個早期版本的jQuery,版本號是1.7.1里面的封裝代碼大致是下面這樣的

復制代碼代碼如下:

(function( window, undefined ) {
var jQuery = (function() {console.log('hello');});
window.jQuery = window.$ = jQuery;
if ( typeof define === "function" && define.amd && define.amd.jQuery ) {
    define( "jquery", [], function () { return jQuery; } );
}
})( window );

 

其中的

復制代碼代碼如下:

console.log('hello');

是用以驗證是否按開頭說的這樣工作,于是我們就可以在window中調用jQuery
復制代碼代碼如下:

window.$

或者是
復制代碼代碼如下:

window.jQuery

 

于是我們就可以創建一個類似的封裝

復制代碼代碼如下:

(function(window, undefined) {
    var PH = function() {

 

    }
})(window)


相比于上面只是少了兩步

 

1.定義jQuery的符號及全局調用
2.異步支持

于是找了下更早期的jQuery的封裝,方法上大致是一樣的, 除了。。

復制代碼代碼如下:

if (typeof window.jQuery == "undefined") {
    var jQuery = function() {};
    if (typeof $ != "undefined")
        jQuery._$ = $;

 

    var $ = jQuery;
};

 

很神奇的判斷方法,以致于我們沒有辦法重寫上一步的jQuery。于是只好看看最新的jQuery的封裝是怎樣的。于是就打開了2.1.1,發現除了加了很多功能以外,基本上思想還是不變的

復制代碼代碼如下:

(function(global, factory) {

 

    if (typeof module === "object" && typeof module.exports === "object") {
        module.exports = global.document ?
            factory(global, true) :
            function(w) {
                if (!w.document) {
                    throw new Error("jQuery requires a window with a document");
                }
                return factory(w);
        };
    } else {
        factory(global);
    }

}(typeof window !== "undefined" ? window : this, function(window, noGlobal) {
    var jQuery = function() {
        console.log('jQuery');
    };
    if (typeof define === "function" && define.amd) {
        define("jquery", [], function() {
            return jQuery;
        });
    };
    strundefined = typeof undefined;
    if (typeof noGlobal === strundefined) {
        window.jQuery = window.$ = jQuery;
    };
    return jQuery;
}));


在使用瀏覽器的情況下
復制代碼代碼如下:

typeof module ="undefined"

所以上面的情況是針對于使用Node.js等的情況下判斷的,這也表明jQuery正在變得臃腫。

 

Backbone 封裝

打開了Backbone看了一下

復制代碼代碼如下:

(function(root, factory) {

 

    if (typeof define === 'function' && define.amd) {
        define(['underscore', 'jquery', 'exports'], function(_, $, exports) {
            root.Backbone = factory(root, exports, _, $);
        });

    } else if (typeof exports !== 'undefined') {
        var _ = require('underscore');
        factory(root, exports, _);

    } else {
        root.Backbone = factory(root, {}, root._, (root.jQuery || root.Zepto || root.ender || root.$));
    }

}(this, function(root, Backbone, _, $) {
    Backbone.$ = $;
    return Backbone;

}));

 

除了異步支持,也體現了其對于jQuery和underscore的依賴,百

復制代碼代碼如下:

        define(['underscore', 'jquery', 'exports'], function(_, $, exports) {
            root.Backbone = factory(root, exports, _, $);
        });

表明backbone是原生支持requirejs的。

 

Underscore 封裝
于是,又看了看Underscore,發現這個庫又占領了一個符號 _

復制代碼代碼如下:

(function() {
    var root = this;
    var _ = function(obj) {
        if (obj instanceof _) return obj;
        if (!(this instanceof _)) return new _(obj);
        this._wrapped = obj;
    };

 

    if (typeof exports !== 'undefined') {
        if (typeof module !== 'undefined' && module.exports) {
            exports = module.exports = _;
        }
        exports._ = _;
    } else {
        root._ = _;
    }

    if (typeof define === 'function' && define.amd) {
        define('underscore', [], function() {
            return _;
        });
    }
}.call(this));


總體上也和差不多都是匿名函數,除了最后用的是call()方法。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 泸西县| 万安县| 榆树市| 宜黄县| 静宁县| 舒兰市| 磐石市| 建阳市| 连江县| 铅山县| 湖北省| 玉溪市| 邻水| 兰溪市| 扶余县| 疏附县| 漳浦县| 财经| 高要市| 永平县| 大渡口区| 高雄县| 德化县| 霞浦县| 安吉县| 桃园市| 彭阳县| 绥宁县| 桐庐县| 溧水县| 阿尔山市| 二连浩特市| 寻乌县| 锦屏县| 滕州市| 梅河口市| 汤阴县| 凌海市| 浮山县| 兰溪市| 乌海市|