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从头学起第四讲 jquery入门教程
Aug 01 Javascript
js修改input的type属性及浏览器兼容问题探讨与解决
Jan 23 Javascript
javascript倒计时效果实现
Nov 12 Javascript
javascript数组去重方法分析
Dec 15 Javascript
Jquery把获取到的input值转换成json
May 15 jQuery
Vue.js 中的 $watch使用方法
May 25 Javascript
关于在mongoose中填充外键的方法详解
Aug 14 Javascript
在vue-cli中组件通信的方法
Dec 16 Javascript
jQuery访问json文件中数据的方法示例
Jan 28 jQuery
JavaScript多种页面刷新方法小结
Apr 04 Javascript
利用不到200行代码写一款属于你自己的js类库
Jul 08 Javascript
解决vuecli3中img src 的引入问题
Aug 04 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
PHP explode()函数用法、切分字符串
2012/10/03 PHP
PHP与MYSQL中UTF8 中文排序示例代码
2014/10/23 PHP
PHP中substr()与explode()函数用法分析
2014/11/24 PHP
学习php开源项目的源码指南
2014/12/21 PHP
php版微信返回用户text输入的方法
2016/11/14 PHP
Laravel5.7 Eloquent ORM快速入门详解
2019/04/12 PHP
用javascript自动显示最后更新时间
2007/03/15 Javascript
jQuery的实现原理的模拟代码 -3 事件处理
2010/08/03 Javascript
ajax中get和post的说明及使用与区别
2012/12/23 Javascript
简单常用的幻灯片播放实现代码
2013/09/25 Javascript
Extjs4实现两个GridPanel之间数据拖拽功能具体方法
2013/11/21 Javascript
基于jquery的simpleValidate简易验证插件
2014/01/31 Javascript
JavaScript中Cookies的相关使用教程
2015/06/04 Javascript
bootstrap table小案例
2016/10/21 Javascript
jQuery实现可兼容IE6的淡入淡出效果告警提示功能示例
2017/09/20 jQuery
vue项目每30秒刷新1次接口的实现方法
2018/12/04 Javascript
基于vue开发微信小程序mpvue-docs跳转页面功能
2019/04/10 Javascript
cordova+vue+webapp使用html5获取地理位置的方法
2019/07/06 Javascript
vue实现点击按钮下载文件功能
2019/10/11 Javascript
python模拟登陆Tom邮箱示例分享
2014/01/13 Python
Python编写生成验证码的脚本的教程
2015/05/04 Python
python爬虫的工作原理
2017/03/05 Python
python3+PyQt5实现自定义分数滑块部件
2018/04/24 Python
Pyspider中给爬虫伪造随机请求头的实例
2018/05/07 Python
Python3监控windows,linux系统的CPU、硬盘、内存使用率和各个端口的开启情况详细代码实例
2020/03/18 Python
优质美利奴羊毛袜,不只是徒步旅行:Darn Tough Vermont
2018/11/05 全球购物
波兰在线运动商店:YesSport
2020/07/23 全球购物
三年级数学教学反思
2014/01/31 职场文书
报纸媒体创意广告词
2014/03/17 职场文书
好习惯伴我成长演讲稿
2014/05/21 职场文书
2014年幼儿园教研工作总结
2014/12/04 职场文书
2015大学生党员自我评价范文
2015/03/03 职场文书
区域销售经理岗位职责
2015/04/02 职场文书
公司前台接待岗位职责
2015/04/03 职场文书
参观监狱警示教育心得体会
2016/01/15 职场文书
nginx常用配置conf的示例代码详解
2022/03/21 Servers