Javascript中的匿名函數(shù)與封裝介紹
迷惑了一會兒不同JS庫的封裝后,終于有了點(diǎn)頭緒。大致就是:
創(chuàng)建一個自調(diào)用匿名函數(shù),設(shè)計(jì)參數(shù)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');
是用以驗(yàn)證是否按開頭說的這樣工作,于是我們就可以在window中調(diào)用jQuery
window.$
或者是
window.jQuery
于是我們就可以創(chuàng)建一個類似的封裝
(function(window, undefined) {
var PH = function() {
}
})(window)
相比于上面只是少了兩步
1.定義jQuery的符號及全局調(diào)用
2.異步支持
于是找了下更早期的jQuery的封裝,方法上大致是一樣的, 除了。。
if (typeof window.jQuery == "undefined") {
var jQuery = function() {};
if (typeof $ != "undefined")
jQuery._$ = $;
var $ = jQuery;
};
很神奇的判斷方法,以致于我們沒有辦法重寫上一步的jQuery。于是只好看看最新的jQuery的封裝是怎樣的。于是就打開了2.1.1,發(fā)現(xiàn)除了加了很多功能以外,基本上思想還是不變的
(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;
}));
除了異步支持,也體現(xiàn)了其對于jQuery和underscore的依賴,百
define(['underscore', 'jquery', 'exports'], function(_, $, exports) {
root.Backbone = factory(root, exports, _, $);
});
表明backbone是原生支持requirejs的。
Underscore 封裝
于是,又看了看Underscore,發(fā)現(xiàn)這個庫又占領(lǐng)了一個符號 _
(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));
總體上也和差不多都是匿名函數(shù),除了最后用的是call()方法。
- js中匿名函數(shù)的N種寫法
- js中匿名函數(shù)的創(chuàng)建與調(diào)用方法分析
- javascript 匿名函數(shù)的理解(透徹版)
- 淺析Javascript匿名函數(shù)與自執(zhí)行函數(shù)
- 詳談JavaScript 匿名函數(shù)及閉包
- Javascript中的回調(diào)函數(shù)和匿名函數(shù)的回調(diào)示例介紹
- js匿名函數(shù)作為函數(shù)參數(shù)詳解
- JS自調(diào)用匿名函數(shù)具體實(shí)現(xiàn)
- js自調(diào)用匿名函數(shù)的三種寫法(推薦)
- Javascript中匿名函數(shù)的多種調(diào)用方式總結(jié)
- JS中超越現(xiàn)實(shí)的匿名函數(shù)用法實(shí)例分析
相關(guān)文章
es7學(xué)習(xí)教程之Decorators(修飾器)詳解
這篇文章主要給大家介紹了關(guān)于es7中Decorators(修飾器)的相關(guān)資料,文中通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。2017-07-07一文掌握J(rèn)avaScript數(shù)組常用工具函數(shù)總結(jié)
這篇文章主要介紹了一文掌握J(rèn)avaScript數(shù)組常用工具函數(shù)總結(jié),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值2022-06-06基于BootStrap Metronic開發(fā)框架經(jīng)驗(yàn)小結(jié)【三】下拉列表Select2插件的使用
本文主要給大家介紹在編輯頁面中常用到的控件Select2,這個控件可以更加豐富傳統(tǒng)的Select下拉列表控件,提供更多的功能和更好的用戶體驗(yàn),2016-05-05javascript browser瀏覽器類型以及版本判斷代碼
在團(tuán)隊(duì)js框架建設(shè)過程中寫的一段瀏覽器判斷代碼,喜歡的朋友可以參考下。2010-04-0430分鐘快速入門掌握ES6/ES2015的核心內(nèi)容(上)
ES6增加了很多新的語法,很多同學(xué)學(xué)習(xí)起來感覺很別扭,有時候也不理解新增加的語法有什么用,對ES6的學(xué)習(xí)也沒有興趣進(jìn)而動力不足、學(xué)習(xí)效率不高。下面這篇文章將通過30分鐘帶大家快速入門掌握ES6/ES2015的核心內(nèi)容,需要的朋友可以參考下。2018-04-04Eclipse去除js(JavaScript)驗(yàn)證錯誤
這篇文章主要是對Eclipse去除js(JavaScript)驗(yàn)證錯誤進(jìn)行了介紹。在Eclipse中,js文件常常會報錯。可以通過如下幾個步驟解決2014-02-02