有一个JSLint选项(实际上是The Good Parts之一),它“需要避免立即调用”,这意味着构造
(function () {
// ...
})();
而是需要写成
(function () {
// ...
}());
我的问题是-谁能解释为什么第二种形式可能会更好?它更具弹性吗?容易出错?与第一种形式相比,它有什么优势?
自问了这个问题之后,我开始理解在功能值和功能值之间进行清晰的视觉区分的重要性。考虑一下立即调用的结果在赋值表达式的右侧的情况:
var someVar = (function () {
// ...
}());
尽管从语法上讲,最外面的括号不是必需的,但是括号开头预先表明了所分配的值不是函数本身,而是函数被调用的结果。
这类似于克罗克福德(Crockford)关于大写构造函数的建议-旨在作为任何查看源代码的人的视觉提示。
来自Douglass Crockford的样式约定指南:(搜索“立即调用”)
当要立即调用一个函数时,应将整个调用表达式包装在括号中,以便清楚地知道所产生的值是函数的结果,而不是函数本身。
因此,从根本上说,他认为这使功能值和功能值之间的区别更加清晰。因此,这是一个风格问题,而不是代码本身的实质差异。
更新的参考,旧的PPT不再存在
问题内容: 我试图创建一个看起来和感觉像标签项的链接,但运行一个函数而不是使用href。 当我尝试将onclick函数应用于链接时,无论该链接从未被单击过,它都会立即调用该函数。此后任何尝试单击链接的尝试都会失败。 我究竟做错了什么? HTML Java脚本 如您所见,我尝试了两种不同的方法来添加此onclick函数,这两种方法具有相同的效果。 问题答案: 你要 不 后者调用(执行),而前者在事件
为什么这在Node.js控制台(在4.1.1和5.3.0中测试)中工作,但在浏览器中不工作(在Chrome中测试)? 这个代码块应该创建并调用一个匿名函数,该函数记录。 另外,当上述操作在节点中工作时。js,这不起作用: 也不是这个: 奇怪的是,当添加参数时,它实际上会在立即调用的部分抛出一个。
前言 大家学JavaScript的时候,经常遇到自执行匿名函数的代码,今天我们主要就来想想说一下自执行。 在详细了解这个之前,我们来谈了解一下“自执行”这个叫法,本文对这个功能的叫法也不一定完全对,主要是看个人如何理解,因为有的人说立即调用,有的人说自动执行,所以你完全可以按照你自己的理解来取一个名字,不过我听很多人都叫它为“自执行”,但作者后面说了很多,来说服大家称呼为“立即调用的函数表达式”。
主要内容:1.将函数转换为IIFE,2.IIFE的要点这是一个JavaScript函数,它会在定义后立即运行。 可以使用IIFE(立即调用函数表达式)来避免从块内部进行变量吊装。 它允许公开访问方法,同时保留函数中定义的变量的私密性。 IIFE是一种设计模式,也称为自执行匿名函数。它包含两个主要部分: 第一部分是具有词法范围的匿名函数,该函数包含在分组运算符中。 第二部分创建IIFE,JavaScript引擎将通过该IIFE直接解释该函数。 语法:
我没有看到这些构造使用很多,但我发现自己编写它们是为了在通常不会返回promise的函数中使用异步/等待 相对于 或 这是一件事吗?这里有我应该意识到的陷阱吗?在这种情况下使用async/wait的原因是什么?
我想在一个HTML页面上做一个值,每5秒更新一次,这样就不会让服务器不堪重负。结果表明,我的函数中的setTimeout()没有适当延迟,而是立即被调用。有人能帮我找个线索吗?我真的不想给我的服务器太多的工作,因为我必须实现更多的Ajax。 代码如下: