>  기사  >  웹 프론트엔드  >  자바스크립트 함수 표현과 함수 선언의 차이점에 대한 간략한 토론_자바스크립트 기술

자바스크립트 함수 표현과 함수 선언의 차이점에 대한 간략한 토론_자바스크립트 기술

WBOY
WBOY원래의
2016-05-16 15:21:501239검색

자바스크립트에서 함수를 선언하는 방법에는 함수 선언과 함수 표현식의 두 가지가 있습니다.

차이점은 다음과 같습니다.

1) 함수선언으로 정의된 함수의 경우 함수명은 필수이고, 함수식의 함수명은 선택사항입니다.

2) 함수 선언으로 정의된 함수의 경우 함수 선언 전에 함수를 호출할 수 있고, 함수 표현식의 함수는 선언 후에만 호출할 수 있습니다.

3) 함수 선언으로 정의된 함수는 실제 선언이 아닙니다. 전역적으로 표시되거나 다른 함수에 중첩되어 표시될 수 있지만 루프, 조건 또는 try/catch/ finally in 및

에는 표시될 수 없습니다.

함수 표현식은 어디서든 선언할 수 있습니다.

함수는 아래 두 가지 방식으로 정의됩니다.

 //函数声明式
 function greeting(){
    console.log("hello world"); 
 }
 
 
 //函数表达式
 var greeting = function(){
   console.log("hello world"); 
 }

아래의 흥미로운 자바스크립트:

function f() { console.log('I am outside!'); }
(function () {
 if(false) {
  // 重复声明一次函数f
  function f() { console.log('I am inside!'); }
 }
 f();
}());

첫 번째 반응은 "I am Outside"여야 합니다. 결과는 Chrome에서 "I am inside"이고 IE11에서는 직접 오류를 보고하며, Firefox 하위 버전에서는 "I am Outside"가 출력됩니다. .

크롬으로 출력되는 결과는 함수 선언을 사용하여 선언된 함수의 특성을 명확하게 반영합니다. 함수는 선언되기 전에 호출될 수 있습니다.

IE 오류는 조건에 함수를 선언했기 때문에 객체가 누락된 것으로 나타나는데, 이는 함수 선언의 원칙에 위배됩니다.

함수 표현 범위:

함수 표현식으로 선언된 함수에 함수 이름이 있는 경우 함수 이름은 함수의 지역 변수와 동일하며 함수 내에서만 호출할 수 있습니다. 예:

var f = function fact(x) { 
        if (x <= 1) 
          return 1;
        else 
          return x*fact(x-1);
        };
        alert(fact());  // Uncaught ReferenceError: fact is not defined

fact()는 함수 내부에서 호출할 수 있지만 함수 외부에서 호출하면 오류가 보고됩니다. 사실이 정의되지 않았습니다.
사실

자세히 살펴보겠습니다

함수 선언

함수 선언 샘플 코드

코드는 다음과 같습니다.

function fn () {
  console.log('fn 函数执行..');
  // code..
}

이렇게 fn이라는 함수를 선언했는데, 이 함수 위에 호출하면 실행될 것 같나요? 아니면 오류가 보고되나요?

코드는 다음과 같습니다. fn(); // 앞에서 선언한 fn 함수를 호출합니다. function fn() { console.log('fn 함수 실행..') // code..}

콘솔 출력:

네, 이때 fn 함수를 호출할 수 있습니다. 이유를 요약하면 다음과 같습니다.

요약:

1: 이때 fn 함수는 변수의 결과로, 기본적으로 전역 컨텍스트의 변수에 저장됩니다(window.function 이름으로 확인 가능)

 2: 이 메소드는 전역 컨텍스트 단계에 들어갈 때 생성되는 함수 선언입니다. 코드 실행 단계에서 이미 사용 가능합니다. ps: 자바스크립트는 메소드에 들어갈 때마다 컨텍스트 환경(글로벌 → 로컬)을 초기화합니다

 3: 변수 객체에 영향을 미칠 수 있음(컨텍스트에 저장된 변수만 해당)

함수 표현

함수 표현 예시 코드

코드는 다음과 같습니다.

var fn = function () {
  console.log('fn 函数【表达式】声明执行..')
  // code..
}

 이런 방식으로 익명 함수를 선언하고 fn 변수에 대한 참조를 지정합니까?

위와 아래에서 다시 한번 표현식으로 선언한 함수를 호출하면 콘솔에 출력되는 모습을 볼 수 있습니다.

코드는 다음과 같습니다.

// 为了清晰的看到控制台的输出,我们在各自调用前后做个标记,增加可读性。
console.log('之前调用开始..');
fn();
console.log('之前调用结束..');
var fn = function () {
  console.log('fn 函数【表达式】声明执行..')
  // code..
}
console.log('之后调用开始..');
fn();
console.log('之后调用开始..');

콘솔 인쇄 결과:

코드가 실행되고 fn() 함수가 처음 호출되면 다음 메시지가 표시되고, fn은 함수가 아닙니다(fn은 메서드가 아닙니다). 오류가 발생하면 작업이 종료됩니다. 마주쳤다.

이는 fn()이 처음 호출되었을 때 var fn 변수가 전역 객체의 속성으로 존재하지 않고, fn이 참조하는 익명 함수 컨텍스트가 초기화되지 않아 이전 호출이 실패했음을 보여줍니다. .

코드는 다음과 같습니다.

// 现在先把之前的调用逻辑给注释掉,再看下控制台的输出
//  console.log('之前调用开始..');
//  fn();
//  console.log('之前调用结束..');
  var fn = function () {
    console.log('fn 函数【表达式】声明执行..')
    // code..
  }
  console.log('之后调用开始..');
  fn(); // 在表达式之后调用
  console.log('之后调用开始..');

콘솔 인쇄 결과:

표현식 함수 이후에 호출이 가능하다고 볼 수 있는 이유를 정리해볼까요?

요약:

1: 우선 변수 자체가 함수로 존재하는 것이 아니라 익명 함수에 대한 참조입니다(값 유형은 참조가 아닙니다)

2: 코드 실행 단계에서 전역 컨텍스트가 초기화되면 전역 속성으로 존재하지 않으므로 변수 객체의 오염이 발생하지 않습니다

3: 이 유형의 선언은 일반적으로 플러그인 개발에서 일반적이며 클로저에서 콜백 함수에 대한 호출로 사용될 수도 있습니다

 그래서 function fn () {}는 var fn = function () {}와 같지 않습니다.

위 내용은 이 기사의 전체 내용입니다. 아이디어가 매우 명확하고 비교도 매우 명확합니다. 친구 여러분, 꼭 읽어보세요

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