- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果这是重复的,我很抱歉,我已经阅读了一些问这个问题的帖子,但我没有找到令人满意的答案。我是 JS 的新手,我使用过 C 和 Java。我最近了解了函数表达式,据我所知,它是分配给某个 const 变量的匿名函数声明。我不明白这背后的动机是什么/它的可能用途是什么/这怎么能做一些你不能只用函数声明做的事情。例如
const example = function (input){
return 'Am I useless?:' + input;
}
console.log(example('Idk'));
这就像用相同的变量调用声明的函数,但我使用的是这个变量名(example
),这也使匿名
函数看起来是伪匿名的,因为它确实有一个可以引用的名称。
我看不出什么时候这比函数声明更可取,但我正在参加的 CodeCademy 类(class)反复使用了函数表达式,所以我一定遗漏了一些东西。
非常感谢您的帮助/说明。
最佳答案
TL;DR:不,函数表达式并非无用。
首先,我会从函数表达式中推导出函数声明,而不是相反。函数声明也很有用,但它们可以完全由函数表达式代替。
主要区别:函数声明总是创建变量,而函数表达式则不会。但是,您仍然可以将它们分配给变量。
以下代码是相同的(好吧,不完全相同,它们的提升规则不同):
function foo(bar){
return 'baz'
}
//Function declarations create variables like how `var` does
var foo = function foo(bar){
return 'baz'
}
但是,当您不想将函数存储到 var
iable 中时,函数表达式会变得很方便。
示例包括:
常量函数:
const foo = function foo(bar){
return 'baz'
}
block 作用域函数:
{
let foo = function foo(bar){
return 'baz'
}
}
IIFE(立即调用的函数表达式):
(function (bar){
//Here we have an encapsulated local scope and the ability to return things
return 'baz'
})('foo')
回调:
asyncFn(function (){
console.log('Done!')
})
存储在对象中:
foo[2].bar = function (){
return 'baz'
}
分配给先前声明的变量:
let foo = null
console.log(foo)
foo = function foo(bar){
return 'baz'
}
而且,尽管从技术上讲,上述所有问题都可以仅通过使用函数声明来解决,但这会导致大量不必要的变量和难以阅读的代码。
我不完全知道为什么代码学院更喜欢在您的案例中使用函数表达式,但我认为关键在于 const
关键字,因为它是:
var
(和函数声明)允许的奇怪怪癖关于javascript - 函数表达式有什么意义,它们似乎没用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61298727/
我有一张 table People (First_Name, Last_Name)。此表包含与示例中一样重复的记录(并非所有行都重复): First_Name Last_Name John
我用 Java 编写过很多程序,之前也涉足过 C++。我在各种 C++ 书籍中阅读了有关指针的内容,并完成了书籍中的各种示例。 我了解指针的基础知识,但有一件事我一直不清楚。指针在现实世界中的应用是什
线 .Mappings(m => m.FluentMappings.AddFromAssemblyOf() 它有什么作用?它会在派生自 ClassMap 的 Product 类的程序集中查找任
我有用于打印数字的自定义打印功能。我制作了一个 ASCII 版本和一个 UTF-16LE 版本。 UTF-16LE 版本对 0-9 使用全角代码/字符,对十六进制使用 A-F。在调试我的函数时,我注意
这是我的代码片段: float ab(float); 以后 if(ab(temp)
我在一个项目文件中包含以下代码: //begin of the file ((window) => { 'use strict'; class View extends GSM.Event
我一直在到处寻找关于 ? 用法的正确解释。和 *。我注意到我可以使用以下方法拒绝所有用户的访问: 如果我想允许某个组,我应该在其上方添加下一行: 但是当我看到人们使用 ? 时,我开始忘记什么意思,
我正在关注 melon js tutorial .这是在我的 HUD.js 文件的顶部。 game.HUD = game.HUD || {} 我以前在其他例子中见过这个。 namespace.some
我正在处理一个包含数千行代码的文件。我正在第 700 行实现一个算法。我经常不得不离开这些行来检查文件中的其他方法。 导航回到我实际编码的地方通常很痛苦。如果我可以在第 700 行设置一个航路点并为其
我遇到了这段代码 do { if (higherQuality && w > targetWidth) { w /= 2; if (w &
uint8_t * const LCDMem = (uint8_t *) &LCDM3; 此代码在 msp430fg4618 培训套件中用于 lcd 配置。谁能解释一下上述代码的含义? 它允许使用 a
上下文 阅读一些内核代码。 问题 我不明白这行是什么意思 *(void **) &(int[2]){0,PAGE_SIZE}; 还有更多,这是什么意思 {0,PAGE_SIZE} 对我来说,它看起来不
我正在查看 Underscore.js 的源代码库,专门用于 map方法(该页面第 85 行左右,并复制到此处): _.map = function(obj, iterator, context)
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
我是一名优秀的程序员,十分优秀!