Javascript中的匿名函数与封装介绍
作者:bea
迷惑了一会儿不同JS库的封装后,终于有了点头绪。大致就是: 代码如下: 创建一个自调用匿名函数,设计参数window,并传入window对象。 而这个过程的目的则是, 代码如下: 使得自身的代码不会被其他代码污染,同时也可以不污染其他代码。 jQuery 封装 于是找了个早期版本的jQuery,版本号是1.7.1里面的封装代码大致是下面这样的 代码如下: (function( window, undefined ) { var jQuery = (
迷惑了一会儿不同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()方法。
有用 | 无用
代码如下:
创建一个自调用匿名函数,设计参数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()方法。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- JavaScript中的方法重载实例
- jquery中attr和prop的区别分析
- JavaScript中扩展Array contains方法实例
- JavaScript中消除闭包的一般方法介绍
- jQuery实现的支持IE的html滑动条
- JavaScript计算两个日期时间段内日期的方法
- nw.js实现类似微信的聊天软件
- JavaScript控制table某列不显示的方法
- 详解addEventListener的三个参数之useCapture
- 解决Jquery向页面append新元素之后事件的绑定问题
- jquery中radio checked问题
- jquery中JSON的解析方式
- 浅谈js中的闭包
- js完美实现@提到好友特效(兼容各大浏览器)
- JavaScript DSL 流畅接口(使用链式调用)实例
- JavaScript中的DSL元编程介绍
- JavaScript中的立即执行函数表达式介绍
- Javascript中的arguments与重载介绍
- JavaScript中的闭包介绍