Javascript中的匿名函数与封装介绍


Posted in Javascript onMarch 15, 2015

迷惑了一会儿不同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()方法。
Javascript 相关文章推荐
基于prototype的validation.js发布2.3.4新版本,让你彻底脱离表单验证的烦恼
Dec 06 Javascript
Prototype String对象 学习
Jul 19 Javascript
jquery的ajax从纯真网(cz88.net)获取IP地址对应地区名
Dec 02 Javascript
再论Javascript下字符串连接的性能
Mar 05 Javascript
js+css实现增加表单可用性之提示文字
Jun 03 Javascript
JS获取屏幕高度的简单实现代码
May 24 Javascript
JS实现简单易用的手机端浮动窗口显示效果
Sep 07 Javascript
js实现颜色阶梯渐变效果(Gradient算法)
Mar 21 Javascript
Angular2中select用法之设置默认值与事件详解
May 07 Javascript
React-Native中props具体使用详解
Sep 04 Javascript
浅谈Koa2框架利用CORS完成跨域ajax请求
Mar 06 Javascript
在Vue-cli里应用Vuex的state和mutations方法
Sep 16 Javascript
Javascript中的方法链(Method Chaining)介绍
Mar 15 #Javascript
Javascript中的apply()方法浅析
Mar 15 #Javascript
Javascript中的Callback方法浅析
Mar 15 #Javascript
Javascript中的call()方法介绍
Mar 15 #Javascript
Javascript中的高阶函数介绍
Mar 15 #Javascript
Javascript中this关键字的一些小知识
Mar 15 #Javascript
Javascript URI 解析介绍
Mar 15 #Javascript
You might like
Yii框架结合sphinx,Ajax实现搜索分页功能示例
2016/10/18 PHP
PHP实现Google plus的好友拖拽分组效果
2016/10/21 PHP
php中通用的excel导出方法实例
2017/12/30 PHP
PHP如何获取Cookie并实现模拟登录
2020/07/16 PHP
JavaScript下申明对象的几种方法小结
2008/10/02 Javascript
jquery一般方法介绍 入门参考
2011/06/21 Javascript
最好用的省市二级联动 原生js实现你值得拥有
2013/09/22 Javascript
js 对小数加法精度处理示例说明
2013/12/27 Javascript
JavaScript对象属性检查、增加、删除、访问操作实例
2015/07/08 Javascript
Node.js+Express配置入门教程
2016/05/19 Javascript
bootstrap datetimepicker日期插件使用方法
2017/01/13 Javascript
jQuery插件MovingBoxes实现左右滑动中间放大图片效果
2017/02/28 Javascript
Vue实现virtual-dom的原理简析
2017/07/10 Javascript
js实现简单页面全屏
2019/09/17 Javascript
layui字体图标 loading图标静止不旋转的解决方法
2019/09/23 Javascript
vue 实现element-ui中的加载中状态
2020/11/11 Javascript
[02:23]2014DOTA2国际邀请赛中国战队回顾
2014/08/01 DOTA
[02:10]2018DOTA2亚洲邀请赛赛前采访-Liquid
2018/04/03 DOTA
[40:17]2018DOTA2亚洲邀请赛 4.5 淘汰赛 LGD vs Liquid 第一场
2018/04/06 DOTA
几种实用的pythonic语法实例代码
2018/02/24 Python
Python实现替换文件中指定内容的方法
2018/03/19 Python
python脚本实现验证码识别
2018/06/07 Python
对python指数、幂数拟合curve_fit详解
2018/12/29 Python
Python logging模块写入中文出现乱码
2020/05/21 Python
Manuka Doctor美国官网:麦卢卡蜂蜜和蜂毒护肤
2016/12/25 全球购物
Bally巴利中国官网:经典瑞士鞋履、手袋及配饰奢侈品牌
2018/10/09 全球购物
Ben Sherman官方网站:英国男装品牌
2019/10/22 全球购物
群众路线教育实践活动方案
2014/02/02 职场文书
2013年研究生毕业感言
2014/02/06 职场文书
机电一体化求职信
2014/03/10 职场文书
爱国卫生月活动总结范文
2014/04/25 职场文书
文明演讲稿范文
2014/05/12 职场文书
法院干警四风问题个人对照检查材料思想汇报
2014/10/07 职场文书
观后感的写法
2015/06/19 职场文书
2016年秋季运动会加油稿
2015/12/21 职场文书
Mysql 如何查询时间段交集
2021/06/08 MySQL