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 相关文章推荐
jquery实现的网页自动播放声音
Apr 30 Javascript
用js通过url传参把数据从一个页面传到另一个页面
Sep 01 Javascript
Internet Explorer 11 浏览器介绍:别叫我IE
Sep 28 Javascript
javascript中String对象的slice()方法分析
Dec 20 Javascript
js分页工具实例
Jan 28 Javascript
JS hashMap实例详解
May 26 Javascript
AngularJs Dependency Injection(DI,依赖注入)
Sep 02 Javascript
jquery插入兄弟节点的操作方法
Dec 07 Javascript
Vue2.0利用vue-resource上传文件到七牛的实例代码
Jul 28 Javascript
vue工程全局设置ajax的等待动效的方法
Feb 22 Javascript
理理Vue细节(推荐)
Apr 16 Javascript
微信小程序 弹窗输入组件的实现解析
Aug 12 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
漫威DC御用漫画家去世 他的表情包曾走红网络
2020/04/09 欧美动漫
GBK的页面输出JSON格式的php函数
2010/02/16 PHP
PHP Static延迟静态绑定用法分析
2016/03/16 PHP
php获取excel文件数据
2017/04/21 PHP
PDO::exec讲解
2019/01/28 PHP
Alliance vs AM BO3 第二场2.13
2021/03/10 DOTA
Javascript 面向对象 继承
2010/05/13 Javascript
jquery实现图片滚动效果的简单实例
2013/11/23 Javascript
JS使用cookie实现DIV提示框只显示一次的方法
2015/11/05 Javascript
javascript数组去重小结
2016/03/07 Javascript
分离与继承的思想实现图片上传后的预览功能:ImageUploadView
2016/04/07 Javascript
javascript ASCII和Hex互转的实现方法
2016/12/27 Javascript
es6系列教程_ Map详解以及常用api介绍
2017/09/25 Javascript
浅谈mint-ui 填坑之路
2017/11/06 Javascript
NodeJs实现定时任务的示例代码
2017/12/05 NodeJs
JS运动特效之链式运动分析
2018/01/24 Javascript
为jquery的ajax请求添加超时timeout时间的操作方法
2018/09/04 jQuery
Python的ORM框架中SQLAlchemy库的查询操作的教程
2015/04/25 Python
Django上使用数据可视化利器Bokeh解析
2019/07/31 Python
Python中IP地址处理IPy模块的方法
2019/08/16 Python
对Tensorflow中Device实例的生成和管理详解
2020/02/04 Python
使用django自带的user做外键的方法
2020/11/30 Python
详解Python Celery和RabbitMQ实战教程
2021/01/20 Python
HTML5 与 XHTML2
2008/10/17 HTML / CSS
使用HTML5的表单验证的简单示例
2015/09/09 HTML / CSS
德国PC硬件网站:CASEKING
2016/10/20 全球购物
Python使用openpyxl复制整张sheet
2021/03/24 Python
劳动之星获奖感言
2014/02/01 职场文书
网页美工求职信
2014/02/15 职场文书
机关作风整顿个人整改措施思想汇报
2014/09/29 职场文书
2014年施工员工作总结
2014/11/18 职场文书
欢送领导祝酒词
2015/08/12 职场文书
创业计划之特色精品店
2019/08/12 职场文书
高中语文教材(文学文化常识大全一)
2019/08/13 职场文书
Python如何使用logging为Flask增加logid
2021/03/30 Python
用Python监控你的朋友都在浏览哪些网站?
2021/05/27 Python