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 相关文章推荐
JS日历 推荐
Dec 03 Javascript
jQuery ready函数滥用分析
Feb 16 Javascript
Javascript面向对象编程(三) 非构造函数的继承
Aug 28 Javascript
jquery 日期控件datepicker属性详细解析
Nov 08 Javascript
解决window.opener=null;window.close(),只支持IE6不支持IE7,IE8的问题
Jan 14 Javascript
js控制元素显示在屏幕固定位置及监听屏幕高度变化的方法
Aug 11 Javascript
jQuery Timelinr实现垂直水平时间轴插件(附源码下载)
Feb 16 Javascript
超实用的JavaScript表单代码段
Feb 26 Javascript
微信小程序 跳转传参数与传对象详解及实例代码
Mar 14 Javascript
vue引入新版 vue-awesome-swiper插件填坑问题
Jan 25 Javascript
Vue中对iframe实现keep alive无刷新的方法
Jul 23 Javascript
jQuery实现checkbox全选、反选及删除等操作的方法详解
Aug 02 jQuery
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
谈一谈收音机的高放电路
2021/03/02 无线电
PHP4之真OO
2006/10/09 PHP
php 删除目录下N分钟前创建的所有文件的实现代码
2013/08/10 PHP
PHP实现的获取文件mimes类型工具类示例
2018/04/08 PHP
有效的捕获JavaScript焦点的方法小结
2009/10/08 Javascript
一个页面元素appendchild追加到另一个页面元素的问题
2013/01/27 Javascript
js控制淡入淡出示例代码
2013/11/12 Javascript
jQuery中操控hidden、disable等无值属性的方法
2014/01/06 Javascript
jquery 判断selection range 是否在容器中的简单实例
2016/08/02 Javascript
js 获取当前web应用的上下文路径实现方法
2016/08/19 Javascript
BootStrap中Table分页插件使用详解
2016/10/09 Javascript
Bootstrap选项卡动态切换效果
2016/11/28 Javascript
微信小程序模板之分页滑动栏
2017/02/10 Javascript
jQuery中 bind的用法简单介绍
2017/02/13 Javascript
原生JS中slice()方法和splice()区别
2017/03/06 Javascript
Vue computed计算属性的使用方法
2017/07/14 Javascript
JS简单实现父子窗口传值功能示例【未使用iframe框架】
2017/09/20 Javascript
使用Vue.js和Element-UI做一个简单登录页面的实例
2018/02/23 Javascript
javascript面向对象三大特征之封装实例详解
2019/07/24 Javascript
layer关闭弹出窗口触发表单提交问题的处理方法
2019/09/25 Javascript
vue 解决数组赋值无法渲染在页面的问题
2019/10/28 Javascript
[56:12]LGD vs Optic Supermajor小组赛D组胜者组决赛 BO3 第一场 6.3
2018/06/04 DOTA
Python中的Numeric包和Numarray包使用教程
2015/04/13 Python
python实现两个文件合并功能
2018/04/01 Python
python 获取指定文件夹下所有文件名称并写入列表的实例
2018/04/23 Python
python3.6环境下安装freetype库和基本使用方法(推荐)
2020/05/10 Python
Python flask路由间传递变量实例详解
2020/06/03 Python
解决keras backend 越跑越慢问题
2020/06/18 Python
使用PyCharm安装pytest及requests的问题
2020/07/31 Python
班主任班级寄语大全
2014/04/04 职场文书
私人委托书格式
2014/09/10 职场文书
2014法院干警廉洁警示教育思想汇报
2014/09/13 职场文书
2015年党建工作汇报材料
2015/06/25 职场文书
科级干部培训心得体会
2016/01/06 职场文书
JavaScript利用html5新方法操作元素类名详解
2021/11/27 Javascript
Android中View.post和Handler.post的关系
2022/06/05 Java/Android