함수 표현식 VS JS 함수 선언, 차이점에 대해 이야기해 보겠습니다.
JavaScript에서 함수 선언과 함수 표현식은 모두 function 키워드를 사용하여 함수를 생성합니다. 둘이 매우 유사하고 쉽게 혼동될 수 있다고 생각하시나요? 다음 기사에서는 함수 표현식과 함수 선언을 분석하고 함수 표현식과 함수 선언의 차이점을 소개합니다.
JavaScript에서 function
키워드는 간단한 작업, 즉 함수 생성을 수행할 수 있습니다. 그러나 키워드를 사용하여 함수를 정의하면 다른 속성을 가진 함수를 만들 수 있습니다. function
关键字可以完成一个简单的工作:创建一个函数。 但是,使用关键字定义函数的方式可以创建具有不同属性的函数。
在本文中,我们来看一下,如何使用function
关键字来定义函数声明和函数表达式,以及这两种函数之间的区别又是什么。
1.函数表达式vs函数声明
函数声明和函数表达式是使用 function
关键字创建函数的2种方法。
举个例子来说明差异,我们创建两个版本的 sums 函数:
function sumA(a, b) { return a + b; } (function sumB(a, b) { return a + b; }); sumA(1, 2); // ??? sumB(1, 2); // ???
动手试试:https://jsfiddle.net/dmitri_pavlutin/8b46yokr/2/
一般情况,像往常一样定义函数(sumA函数
)。在另一种情况下,函数被放置在一对括号中(sumB函数
)。
如果调用 sumA(1,2)
和 sumB(1,2)
会发生什么?
如预期的那样,sumA(1, 2)
返回 3
。但是,调用sumB(1, 2)
会引发异常:Uncaught ReferenceError: sumB is not defined
。
其原因是sumA
是使用函数声明创建的,该函数声明在当前作用域中创建一个函数变量(具有与函数名称相同的名称)。 但是sumB
是使用函数表达式创建的(将其包装在括号中),该函数表达式不会在当前作用域内创建函数变量。
如果你想访问使用函数表达式创建的函数,那么将函数对象保存到一个变量中:
// Works! const sum = (function sumB(a, b) { return a + b; }); sum(1, 2); // => 3
如果语句以`function
`关键字开头,则为函数声明,否则为函数表达式。
// 函数声明:以`function`关键字开头 function sumA(a, b) { return a + b; } // 函数表达式:不以`function`关键字开头 const mySum = (function sumB(a, b) { return a + b; }); // 函数表达式:不以`function`关键字开头 [1, 2, 3].reduce(function sum3(acc, number) { return acc + number });
从更高的角度来看,函数声明对于创建独立函数很有用,但是函数表达式可以用作回调。
现在,我们更深入地研究函数声明和函数表达式的行为。
2.函数声明
在前面的示例中已经看到的,sumA
是一个函数声明:
// Function declaration function sumA(a, b) { return a + b; } sumA(4, 5); // => 9
当一个语句包含function
关键字,后跟函数名称,一对带参数的括号(param1, param2, paramN)
以及包围在一对花括号{}
中的函数主体时,就会发生函数声明。
函数声明会创建一个函数变量:一个与函数名称同名的变量(例如,上一个示例中的sumA
)。 在当前作用域中(在函数声明之前和之后),甚至在函数作用域本身内,都可以访问该函数变量。
函数变量通常用于调用函数或将函数对象传递给其他函数(传递给高阶函数)。
例如,编写一个函数 sumArray(array)
,以递归方式累加一个数组的项(该数组可以包含数字或其他数组):
sumArray([10, [1, [5]]]); // => 16 function sumArray(array) { let sum = 0; for (const item of array) { sum += Array.isArray(item) ? sumArray(item) : item; } return sum; } sumArray([1, [4, 6]]); // => 11
动手试试:https://jsfiddle.net/dmitri_pavlutin/n7wcryuo/
function sumArray(array) { ... }
是函数声明。
包含函数对象的函数变量sumArray
在当前作用域中可用:sumArray([10, [1, [5]]])
之前和sumArray([1, [4, 6]])
之后,函数声明, 以及函数本身的作用域sumArray([1, [4, 6]])
(允许递归调用)。
由于提升,函数变量在函数声明之前可用。
2.1 函数声明的注意事项
函数声明语法的作用是创建独立函数。 函数声明应在全局作用域内,或直接在其他函数的作用域内:
// Good! function myFunc1(param1, param2) { return param1 + param2; } function bigFunction(param) { // Good! function myFunc2(param1, param2) { return param1 + param2; } const result = myFunc2(1, 3); return result + param; }
基于相同的原因,不建议在条件(if
)和循环(while
,for
)中使用函数声明:
// Bad! if (myCondition) { function myFunction(a, b) { return a * b; } } else { function myFunction(a, b) { return a + b; } } myFunction(2, 3);
使用函数表达式更好地执行有条件地创建函数。
3.函数表达式
当function
关键字在表达式内部创建函数(带有或不带有名称)时,将出现函数表达式。
以下是使用表达式创建的函数的示例:
// Function expressions const sum = (function sumB(a, b) { return a + b; }); const myObject = { myMethod: function() { return 42; } }; const numbers = [4, 1, 6]; numbers.forEach(function callback(number) { console.log(number); // logs 4 // logs 1 // logs 1 });
在函数表达式中创建了两种函数:
- 如果表达式中的函数没有名称,例如
function(){return 42}
,那是一个匿名函数表达式 - 如果函数具有名称,例如 上一个示例中的
sumB
이 글에서는
function
키워드를 사용하여 함수 선언과 함수 표현식을 정의하는 방법과 두 함수의 차이점을 살펴보겠습니다. 1. 함수 표현식과 함수 선언함수 선언과 함수 표현식은 function
키워드를 사용하여 함수를 만드는 두 가지 방법입니다.
차이점을 설명하기 위해 두 가지 버전의 sums 함수를 만듭니다.
// Functions created conditionally let callback; if (true) { callback = function() { return 42 }; } else { callback = function() { return 3.14 }; } // Functions used as callbacks [1, 2, 3].map(function increment(number) { return number + 1; }); // => [2, 3, 4]
🎜 일반적인 경우에는 평소와 같이 함수를 정의합니다(직접 시도해 보세요: https://jsfiddle.net/dmitri_pavlutin/8b46yokr/2/
sumA 함수
). 또 다른 경우에는 함수가 한 쌍의 괄호 안에 배치됩니다(sumB 함수
). 🎜🎜sumA(1,2)
및 sumB(1,2)
를 호출하면 어떻게 되나요? 🎜🎜예상대로 sumA(1, 2)
는 3
을 반환합니다. 그러나 sumB(1, 2)
를 호출하면 Uncaught ReferenceError: sumB가 정의되지 않았습니다
라는 예외가 발생합니다. 🎜🎜이유는 sumA
가 현재 범위에서 함수 변수(함수 이름과 동일한 이름으로)를 생성하는 함수 선언을 사용하여 생성되기 때문입니다. 그러나 sumB
는 현재 범위에서 함수 변수를 생성하지 않는 함수 표현식(괄호로 묶음)을 사용하여 생성됩니다. 🎜🎜함수 표현식을 사용하여 생성된 함수에 액세스하려면 함수 개체를 변수에 저장하세요. 🎜const numbers = [4]; numbers.forEach(function callback(number) { console.log(callback); // logs function() { ... } }); console.log(callback); // ReferenceError: callback is not defined
function
` 키워드로 시작하면 함수 선언입니다. , 그렇지 않으면 함수 표현식입니다. 🎜const callback = function(number) { console.log(callback); // logs function() { ... } }; const numbers = [4]; numbers.forEach(callback); console.log(callback); // logs function() { ... }
🎜2. 함수 선언🎜
🎜이전 예에서 본 것처럼sumA
는 함수 선언입니다.🎜rrreee🎜문에 함수< /가 포함된 경우 code> 키워드, 함수 이름, 매개변수가 포함된 괄호 쌍 <code>(param1, param2, paramN)
, 중괄호 쌍 {}</code으로 묶인 함수 본문 > 이면 함수 선언이 발생합니다. 🎜🎜함수 선언은 함수 변수, 즉 함수 이름과 동일한 이름을 가진 변수를 생성합니다(예: 이전 예의 <code>sumA
). 함수 변수는 현재 범위(함수 선언 전후) 및 함수 범위 자체 내에서도 액세스할 수 있습니다. 🎜🎜함수 변수는 일반적으로 함수를 호출하거나 함수 객체를 다른 함수에 전달(고차 함수에 전달)하는 데 사용됩니다. 🎜🎜예를 들어, 배열의 항목을 반복적으로 누적하는 함수 sumArray(array)
를 작성하세요(배열에는 숫자나 다른 배열이 포함될 수 있음). 🎜rrreee🎜 사용해 보세요: https: //jsfiddle.net/dmitri_pavlutin/n7wcryuo/🎜🎜
function sumArray(array) { ... }
는 함수 선언입니다. 🎜🎜함수 개체가 포함된 함수 변수 sumArray
는 현재 범위(sumArray([10, [1, [5]]])
및 sumArray)에서 사용할 수 있습니다. ([1, [4, 6]])
이후 함수 선언과 함수 자체의 범위 sumArray([1, [4, 6]])
(재귀적) 통화가 허용됩니다). 🎜🎜호이스팅으로 인해 함수가 선언되기 전에 함수 변수를 사용할 수 있습니다. 🎜🎜🎜2.1 함수 선언 시 주의 사항🎜🎜🎜함수 선언 구문은 독립적인 함수를 생성하는 것입니다. 함수 선언은 전역 범위에 있거나 다른 함수의 범위에 직접 있어야 합니다.🎜rrreee🎜같은 이유로 조건문(if
)과 루프(while)를 사용하지 않는 것이 좋습니다.
, for
) 함수 선언 사용: 🎜rrreee🎜함수 표현식을 사용하면 조건부 함수 생성을 더 잘 실행할 수 있습니다. 🎜🎜3. 함수 표현식🎜
🎜function
키워드가 표현식 내에서 (이름 유무와 관계없이) 함수를 생성할 때 함수 표현식이 발생합니다. 🎜🎜다음은 표현식을 사용하여 생성된 함수의 예입니다. 🎜rrreee🎜함수 표현식에는 두 가지 유형의 함수가 생성됩니다. 🎜- 표현식의 함수에 이름이 없으면 다음과 같습니다.
function() {return 42}
, 즉 익명 함수 표현식입니다. 🎜 - 함수에 이전 예의
sumB
와 같은 이름이 있고 콜백이면 이것은 명명된 함수 표현식입니다 🎜🎜🎜🎜3.1 함수 표현식에 대한 참고 사항 🎜🎜🎜 함수 표현식은 조건으로 생성된 콜백이나 함수에 적합합니다. 🎜rrreee🎜 명명된 함수 표현식을 생성한 경우 함수 변수는 생성된 함수의 범위 내에만 있습니다. 사용 가능:🎜const numbers = [4]; numbers.forEach(function callback(number) { console.log(callback); // logs function() { ... } }); console.log(callback); // ReferenceError: callback is not defined
로그인 후 복사로그인 후 복사试一试:https://jsfiddle.net/dmitri_pavlutin/sujwmp10/2/
callback
是一个命名的函数表达式,因此callback函数变量仅在callback()
函数使用域可用,而在外部则不可用。但是,如果将函数对象存储到常规变量中,则可以在函数作用域内外从该变量访问函数对象:
const callback = function(number) { console.log(callback); // logs function() { ... } }; const numbers = [4]; numbers.forEach(callback); console.log(callback); // logs function() { ... }
로그인 후 복사로그인 후 복사试一试:https://jsfiddle.net/dmitri_pavlutin/1btmrcu2/1/
4. 总结
根据使用
function
关键字创建函数的方式,可以通过两种方法来创建函数:函数声明和函数表达式。留个问题:
function sum(a, b) { return a + b } + 1
是函数声明还是函数表达式,可以在留言中说出你的答案。英文文章地址:https://dmitripavlutin.com/javascript-function-expressions-and-declarations/
作者:Dmitri Pavlutin
更多编程相关知识,请访问:编程视频!!
위 내용은 함수 표현식 VS JS 함수 선언, 차이점에 대해 이야기해 보겠습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











C++의 기본 매개변수는 함수 매개변수의 기본값을 지정하는 기능을 제공하여 코드 가독성, 단순성 및 유연성을 향상시킵니다. 기본 매개변수 선언: 함수 선언에서 매개변수 뒤에 "=" 기호를 추가하고 그 뒤에 기본값을 추가합니다. 사용법: 함수 호출 시 선택적 매개변수가 제공되지 않으면 기본값이 사용됩니다. 실제 사례: 두 숫자의 합을 계산하는 함수입니다. 한 매개변수는 필수이고 다른 매개변수는 선택사항이며 기본값은 0입니다. 장점: 향상된 가독성, 향상된 유연성, 상용구 코드 감소. 참고: 선언에서만 지정할 수 있고 끝에 있어야 하며 유형이 호환되어야 합니다.

WebSocket 및 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법 소개: 지속적인 기술 개발로 음성 인식 기술은 인공 지능 분야의 중요한 부분이 되었습니다. WebSocket과 JavaScript를 기반으로 한 온라인 음성 인식 시스템은 낮은 대기 시간, 실시간, 크로스 플랫폼이라는 특징을 갖고 있으며 널리 사용되는 솔루션이 되었습니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법을 소개합니다.

WebSocket과 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 서론: 인터넷 기술의 급속한 발전과 함께 실시간 모니터링 시스템이 다양한 분야에서 널리 활용되고 있다. 실시간 모니터링을 구현하는 핵심 기술 중 하나는 WebSocket과 JavaScript의 조합입니다. 이 기사에서는 실시간 모니터링 시스템에서 WebSocket 및 JavaScript의 적용을 소개하고 코드 예제를 제공하며 구현 원칙을 자세히 설명합니다. 1. 웹소켓 기술

JavaScript 및 WebSocket을 사용하여 실시간 온라인 주문 시스템을 구현하는 방법 소개: 인터넷의 대중화와 기술의 발전으로 점점 더 많은 레스토랑에서 온라인 주문 서비스를 제공하기 시작했습니다. 실시간 온라인 주문 시스템을 구현하기 위해 JavaScript 및 WebSocket 기술을 사용할 수 있습니다. WebSocket은 TCP 프로토콜을 기반으로 하는 전이중 통신 프로토콜로 클라이언트와 서버 간의 실시간 양방향 통신을 실현할 수 있습니다. 실시간 온라인 주문 시스템에서는 사용자가 요리를 선택하고 주문을 하면

WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법 오늘날의 디지털 시대에는 점점 더 많은 기업과 서비스에서 온라인 예약 기능을 제공해야 합니다. 효율적인 실시간 온라인 예약 시스템을 구현하는 것이 중요합니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. WebSocket이란 무엇입니까? WebSocket은 단일 TCP 연결의 전이중 방식입니다.

C++에서 함수 선언 및 정의의 순서는 컴파일 및 연결 프로세스에 영향을 미칩니다. 가장 일반적인 방법은 선언을 먼저 하고 정의를 나중에 하는 것입니다. 둘 다 동시에 존재하는 경우 "forwarddeclaration"을 사용하여 정의를 배치할 수도 있습니다. 컴파일러는 선언을 무시하고 정의만 사용합니다.

JavaScript 및 WebSocket: 효율적인 실시간 일기 예보 시스템 구축 소개: 오늘날 일기 예보의 정확성은 일상 생활과 의사 결정에 매우 중요합니다. 기술이 발전함에 따라 우리는 날씨 데이터를 실시간으로 획득함으로써 보다 정확하고 신뢰할 수 있는 일기예보를 제공할 수 있습니다. 이 기사에서는 JavaScript 및 WebSocket 기술을 사용하여 효율적인 실시간 일기 예보 시스템을 구축하는 방법을 알아봅니다. 이 문서에서는 특정 코드 예제를 통해 구현 프로세스를 보여줍니다. 우리

사용법: JavaScript에서 insertBefore() 메서드는 DOM 트리에 새 노드를 삽입하는 데 사용됩니다. 이 방법에는 삽입할 새 노드와 참조 노드(즉, 새 노드가 삽입될 노드)라는 두 가지 매개 변수가 필요합니다.
