익명기능
함수는 JavaScript에서 가장 유연한 객체입니다. 여기서는 익명 함수의 사용에 대해서만 설명합니다.
익명함수 : 함수명이 없는 함수입니다.
함수의 정의, 먼저 함수의 정의를 간략하게 소개합니다. 크게 3가지로 나눌 수 있습니다
첫 번째 유형: 가장 일반적인 유형이기도 합니다
function double(x){ return 2 * x; }
두 번째 방법: 이 방법은 Function 생성자를 사용하고 매개변수 목록과 함수 본문을 모두 문자열로 처리하므로 매우 불편하므로 권장되지 않습니다.
var double = new Function('x', 'return 2 * x;');
세 번째 유형:
var double = function(x) { return 2* x; }
참고로 "=" 오른쪽에 있는 함수는 익명 함수입니다. 함수를 생성한 후 해당 함수는 square 변수에 할당됩니다.
JavaScript에는 블록 수준 범위 개념이 없습니다. 즉, 블록 수준 명령문에 정의된 변수는 실제로 명령문이 아닌 포함 함수(외부 함수)에서 생성됩니다.
function outputNumber(count){ for(var i=0;i<1000;i++){ alert(i); } alert(i); //count }
Java, C# 등의 언어에서 이 함수의 경우 변수 i는 for 루프 문에서만 정의되며 루프가 끝나면 i가 삭제됩니다. 하지만 JavaScript에서는 i 변수가 outputNumber() 액티비티 객체에 정의되어 있으므로 정의되는 즉시 함수 내에서 액세스할 수 있습니다. 동일한 변수를 다시 선언하더라도 해당 값은 변경되지 않습니다.
function outputNumber(count){ for(var i=0;i<1000;i++){ alert(i); } var i; //重新声明变量 alert(i); //count }
익명 함수를 사용하면 블록 수준 범위를 모방하고 이 문제를 피할 수 있습니다. 블록 수준 범위(개인 범위라고도 함)로 사용되는 익명 함수의 구문은 다음과 같습니다.
(function(){ //这是块级作用域 })()
위 코드 정의는 익명 함수를 호출하고 함수 선언을 괄호로 묶어 함수 표현식임을 나타냅니다. 그 뒤에 오는 또 다른 괄호 쌍은 즉시 함수를 호출합니다.
일시적으로 일부 변수가 필요할 때마다 비공개 범위를 사용할 수 있습니다. 예를 들면 다음과 같습니다.
function outputNumber(count){ (function(){ for(var i=0;i<1000;i++){ alert(i); })(); alert(i); //导致一个错误 }
이런 방식으로 for 루프 외부에 비공개 범위를 삽입합니다. 익명 함수에 정의된 모든 변수는 실행이 끝나면 삭제됩니다.
이 기술은 전역 범위에 너무 많은 변수와 함수를 추가하는 것을 제한하기 위해 전역 범위의 함수 외부에서 자주 사용됩니다.
일반적으로 전역 범위에 변수와 함수를 추가하는 것을 최소화해야 합니다.
이 접근 방식은 익명 함수에 대한 참조가 없고 해당 범위 체인이 함수가 실행되는 동안 즉시 삭제될 수 있기 때문에 클로저가 메모리를 차지하는 문제를 줄일 수 있습니다.