javascript自执行函数

 更新时间:2017年02月10日 10:23:38   作者:yanhangtian  
本文主要介绍了javascript自执行函数的相关知识。具有很好的参考价值,下面跟着小编一起来看下吧
function (window, $, undefined) {
 play=function(){
  $("#demo").val("This is a demo.");
 }
 window.wbLogin = play;
})(window, jQuery);

像上边这样的代码为什么要把window, jQuery对象传进去?

为什么要传入 jQuery?

通过定义一个匿名函数,创建了一个“私有”的命名空间,该命名空间的变量和方法,不会破坏全局的命名空间。这点非常有用也是一个 JS 框架必须支持的功能,jQuery 被应用在成千上万的 JavaScript 程序中,必须确保 jQuery 创建的变量不能和导入他的程序所使用的变量发生冲突。

为什么要传入 window?

通过传入 window 变量,使得 window 由全局变量变为局部变量,当在 jQuery 代码块中访问 window 时,不需要将作用域链回退到顶层作用域,这样可以更快的访问 window;这还不是关键所在,更重要的是,将 window 作为参数传入,可以在压缩代码时进行优化,看看 jquery-1.6.1.min.js:

(function(a,b){})(window); // window 被优化为 a

为什么要传入 undefined?

在自调用匿名函数的作用域内,确保 undefined 是真的未定义。因为 undefined 能够被重写,赋予新的值。

一句话,使全局变量以参数形式变成自执行函数内部的局部变量。

至于为什么这么做,提高程序效率。为什么能提高效率,得从javascript的机制说起,所谓的scope chain作用域链,在当前作用域中如果没有该属性(局部变量)则向上一层作用域中寻找,一直到最上层,也就是window。也就是说全局变量和下级作用域都是window的一个属性,向下依此类推。

另外jQuery传入后将参数写成$可以保证在此函数内$为jquery而不是其他类似使用$符号的库。

undefined同理,由于没有传入第三个参数,自然就是undefined。由于javascript中undefined是一个变量,可以被改变,所以这样可以保证undefined判断时的准确性。有时判断时使用typeof xxx === 'undefined'也是因为这个原因。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

相关文章

  • JavaScript事件流之事件处理和传播机制深入理解

    JavaScript事件流之事件处理和传播机制深入理解

    本文将详细介绍JavaScript事件流的发展流程、属性以及应用场景,并提供一些代码示例和引用资料,帮助读者深入理解并应用这一重要的前端技术,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • JavaScript针对SPA应用的前端优化策略概述

    JavaScript针对SPA应用的前端优化策略概述

    前端性能优化是Web开发中非常重要的一环,优化能够有效地提高网站的加载速度和用户体验,而对于SPA来说,由于其特殊的加载方式和数据交互方式,其优化策略也具有一定的特殊性,需要详细了解可以参考下文
    2023-05-05
  • Js sort排序使用方法

    Js sort排序使用方法

    javascript 中 array.sort() 中的参数,需要传入的是一个函数,而且必须是一个函数
    2011-10-10
  • Electron 隐藏顶部菜单功能实现

    Electron 隐藏顶部菜单功能实现

    本文介绍了如何在Electron应用中隐藏顶部菜单,具体方法是在main.js文件中添加一行代码,这是一个简单有效的技巧,适用于需要简化界面的Electron应用
    2024-09-09
  • 用户输入密码的强度

    用户输入密码的强度

    用户输入密码的强度...
    2006-07-07
  • js下将金额数字每三位一逗号分隔

    js下将金额数字每三位一逗号分隔

    这篇文章主要介绍了js下将金额数字每三位一逗号分隔的相关资料,还附加了一个小功能,小数位保留两位,感兴趣的小伙伴们可以参考一下
    2016-02-02
  • 跟我学习javascript的闭包

    跟我学习javascript的闭包

    跟我学习javascript的闭包,这篇文章的目的就是让大家对javascript闭包有一个非常全面的了解,感兴趣的小伙伴们可以参考一下。
    2015-11-11
  • 基于RequireJS和JQuery的模块化编程——常见问题全面解析

    基于RequireJS和JQuery的模块化编程——常见问题全面解析

    下面小编就为大家带来一篇基于RequireJS和JQuery的模块化编程——常见问题全面解析。小编觉得挺不错的,现在分享给大家,也给大家做个参考
    2016-04-04
  • 关于JavaScript命名空间的一些心得

    关于JavaScript命名空间的一些心得

    这篇文章主要介绍了关于JavaScript命名空间的一些心得,分别给出了顶级、多级命名空间的例子,需要的朋友可以参考下
    2014-06-06
  • JS中使用变量保存arguments对象的方法

    JS中使用变量保存arguments对象的方法

    这篇文章主要介绍了JS中使用变量保存arguments对象的方法的相关资料,非常不错具有参考借鉴价值,需要的朋友可以参考下
    2016-06-06

最新评论