>  기사  >  웹 프론트엔드  >  JavaScript 익명 함수는 블록 수준의scope_javascript 기술을 모방합니다.

JavaScript 익명 함수는 블록 수준의scope_javascript 기술을 모방합니다.

WBOY
WBOY원래의
2016-05-16 15:26:121508검색

익명기능

함수는 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 루프 외부에 비공개 범위를 삽입합니다. 익명 함수에 정의된 모든 변수는 실행이 끝나면 삭제됩니다.

이 기술은 전역 범위에 너무 많은 변수와 함수를 추가하는 것을 제한하기 위해 전역 범위의 함수 외부에서 자주 사용됩니다.

일반적으로 전역 범위에 변수와 함수를 추가하는 것을 최소화해야 합니다.

이 접근 방식은 익명 함수에 대한 참조가 없고 해당 범위 체인이 함수가 실행되는 동안 즉시 삭제될 수 있기 때문에 클로저가 메모리를 차지하는 문제를 줄일 수 있습니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.