原文地址:What (function (window, document, undefined) {})(window, document); really means

按原文翻译

在这篇文章中,我们将探讨标题所暗示的内容,并解释自调用函数设置给我们带来了什么。

有趣的是,我被问到关于IIFE(即时调用的函数表达式)的很多,它采用以下设置:

(function (window, document, undefined) {
//
})(window, document);

那么为什么不写一篇关于它的文章呢? :-)

首先,这是一系列不同的事情。从顶部:

JavaScript具有函数作用域,因此首先创建了一些需要的“私有范围”。例如:

(function (window, document, undefined) {
var name = 'Todd';
})(window, document); console.log(name); //name is not defined,它在一个不同的范围内

Simple.

一个正常函数是这样的:

var logMyName = function (name) {
console.log(name);
}; logMyName('Todd');

我们可以选择调用它,在任何我们需要/想的位置。

“IIFE”之所以被创造出来是因为它们是直接调用的函数表达式。

这意味着它们在运行时被立即调用,

我们也不能再调用它们了,它们只运行一次:

var logMyName = (function (name) {
console.log(name); // Todd
})('Todd');

这里的秘诀是,(我在前面的例子中给一个变量赋值):

(function () {

})();

多余的一对括号是必要的,因为这样不起作用:

function () {

}();

虽然可以通过一些技巧来欺骗JavaScript“使其工作”。
这样强制JavaScript解析器处理 ! 后面的代码:

!function () {

}();

还有其他的变体:

+function () {

}();
-function () { }();
~function () { }();

但我不会用它们。

请参阅@ mariusschulz分解JavaScript的IIFE语法,详细解释IIFE语法及其变体。

https://blog.mariusschulz.com/2016/01/13/disassembling-javascripts-iife-syntax

现在我们知道了它是如何运作的,我们可以将论证传递给我们的 IIFE:

(function (window) {

})(window);

它是如何工作的呢?
记住, (window); 是调用函数的地方,
我们通过窗口对象。
然后这个函数被传递到函数中,我也把它命名为window。
你可以认为这是毫无意义的,因为我们应该给它命名不同的东西,但是现在我们也将使用窗口。

我们还能做什么呢?把所有的东西都传过去!让我们通过文档对象:

(function (window, document) {
// 我们通常需要 window 和 document
})(window, document);

那么关于 undefined 呢?

在ECMAScript 3中,未定义的是可变的。

这意味着它的值可以被重新分配,比如undefined = true;

oh my! 幸运的是,在 ECMAScript 5 中的 ('use strict';)语法将会抛出一个错误告诉你你是一个白痴。

在此之前,我们开始保护自己的 IIFE:

(function (window, document, undefined) {

})(window, document);

也就是说,如果有人来做这件事,我们会没事的:

undefined = true;
(function (window, document, undefined) {
// undefined 是一个局部未定义的变量
})(window, document);

缩小局部变量是IIFE模式的神奇之处。
如果传入的是局部变量名,
所以我们可以随意的命名。

(function (window, document, undefined) {
console.log(window); // Object window
})(window, document); (function (a, b, c) {
console.log(a); // Object window
})(window, document);

想象一下,你对函数库、window 和 document 的所有引用都很好地缩小了。
当然你不需要停下来,
我们也可以通过jQuery,或者在词汇范围内可以使用的方法:

(function ($, window, document, undefined) {
// use $ to refer to jQuery
// $(document).addClass('test');
})(jQuery, window, document); (function (a, b, c, d) {
// becomes
// a(c).addClass('test');
})(jQuery, window, document);

这也意味着您不需要调用jQuery.noConflict();
或者任何东西作为$被分配到模块的本地。
了解范围和全局/局部变量如何工作将进一步帮助您。

还剩下一小段,不想看了,饿了。感觉好像被塞了一把JS的知识。

原因只是我想知道这样一段代码什么意思。

(function (angular) {
'use strict'; //do something })(window.angular);

JS (function (window, document, undefined) {})(window, document)的真正含义的更多相关文章

  1. (译)(function (window, document, undefined) {})(window, document); 真正的意思

    由于非常感兴趣, 我查询了很多关于IIFE (immediately-invoked function expression)的东西, 如下: (function (window, document, ...

  2. javascript匿名函数自执行 (function(window,document,undefined){})(window,document);

    使用匿名自执行函数的作用: (function(window,document,undefined){})(window,document); 1.首先匿名函数 (function(){}) (); ...

  3. (function (window, document, undefined) {})(window, document)什么意思?

    1.IIFE(即时调用的函数表达式),它采取以下表达式: (function (window, document, undefined) { // })(window, document); Java ...

  4. 详解jquery插件中(function ( $, window, document, undefined )的作用。

    1.(function(window,undefined){})(window); Q:(function(window,undefined){})(window);中为什么要将window和unde ...

  5. js实现跨域(jsonp, iframe+window.name, iframe+window.domain, iframe+window.postMessage)

    一.浏览器同源策略 首先我们需要了解一下浏览器的同源策略,关于同源策略可以仔细看看知乎上的一个解释.传送门 总之:同协议,domain(或ip),同端口视为同一个域,一个域内的脚本仅仅具有本域内的权限 ...

  6. window.showModalDialog与window.open()使用

    window.showModalDialog 有些浏览器不兼容,尝试用window.open() 封装替代,需要打开子窗口后向父窗口传递数据. <html> <script src= ...

  7. 详解jquery插件中;(function ( $, window, document, undefined )的作用

    在jquery插件中我们经常看到以下这段代码 1 2 3 ;(function ( $, window, document, undefined ){ //函数体内具体代码 })(jQuery, wi ...

  8. jquery插件中(function ( $, window, document, undefined )的作用

    在jquery插件中我们经常看到以下这段代码 ;(function ( $, window, document, undefined ){ //函数体内具体代码 })(jQuery, window,d ...

  9. ;(function($,window,document,undefined){})(jQuery,window,document)

    ;(function($,window,document,undefined){})(jQuery,window,doucment) 1.自调函数(function(){})() 2.好处是不会产生任 ...

随机推荐

  1. 59、synchronized同步代码块

    synchronized同步方法的问题 有些情况下,在方法上面加synchronized同步,会有性能问题.请看下面代码,来计算下两个线程执行的耗时: package com.sutaoyu.Thre ...

  2. php登陆界面刷新验证码 javascript 的写法

    <script type="text/javascript"> function refreshVerify(){ var imgId = document.getEl ...

  3. dockerfile创建镜像及容器

    第一步: 从王总git上:http://git.oursdata.com/wangyue/dockerfiles.git 进入下图的文件夹中 然后执行以下的说明执行步骤   第二步: 开发环境dock ...

  4. C - A Plug for UNIX (又是建图坑)

    题目链接:https://cn.vjudge.net/contest/68128#problem/C 没理解好题意真的麻烦,一上午就这么过去了..... 具体思路:按照 源点 ->插座-> ...

  5. 20165329 Java实验二:面向对象编程

    实验内容: 面向对象程序设计-1 实验要求: 提交最后三个JUnit测试用例(正常情况,错误情况,边界情况)都通过的截图 实验步骤: 1.按照老师博客的要求新建一个MyUtil项目 在src内新建ja ...

  6. 一个不错的linux学习资料下载的网址

    本文比较完整的讲述GNU make工具,涵盖GNU make的用法.语法.同时重点讨论如何为一个工程编写Makefile.作为一个Linux程序员,make工具的使用以及编写Makefile是必需的. ...

  7. spring boot 测试用例

    junit 是一个面向于研发人员使用的轻量的测试模块,适合做单元测试.而testng百度后发现更强大,可以做功能测试,但对于我这种RD,貌似junit足沟了呢! java Mock PowerMock ...

  8. j-linkV8固件更新(任意版本)

    在使用j-link v8调试程序时,容易出现固件丢失或出错的情况,导致电脑不能识别,j-link上面的灯不亮.我今天刚刚遇到了这个情况,于是就拆开外壳,在网上搜索资料,发现刷固件相关的还真多,但是有一 ...

  9. vue总结05 过渡--状态过渡

    状态过渡 Vue 的过渡系统提供了非常多简单的方法设置进入.离开和列表的动效.那么对于数据元素本身的动效呢,比如: 数字和运算 颜色的显示 SVG 节点的位置 元素的大小和其他的属性 所有的原始数字都 ...

  10. python网络编程-动态导入和断言

    一:动态导入importlib 在程序运行的过程中,根据变量或者配置动态的决定导入哪个模块,可以使用模块importlib importlib使用示例 二:断言assert 如果接下来的程序依赖于前面 ...