>웹 프론트엔드 >JS 튜토리얼 >javascript_javascript 스킬에서 함수 선언과 함수 표현의 차이점에 대한 간략한 분석

javascript_javascript 스킬에서 함수 선언과 함수 표현의 차이점에 대한 간략한 분석

WBOY
WBOY원래의
2016-05-16 16:13:531019검색

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

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

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

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

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

에는 표시될 수 없습니다.

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

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

코드 복사 코드는 다음과 같습니다.

//함수 선언
함수 인사말(){
console.log("안녕하세요")
}
//함수 표현
var 인사말 = 함수(){
console.log("안녕하세요")
}

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

코드 복사 코드는 다음과 같습니다.

function f() { console.log('나는 밖에 있어요!') }
(함수 () {
if(false) {
// 함수 f 선언을 반복합니다
Function f() { console.log('나는 안에 있어요!') }
}
f();
}());

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

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

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

함수 표현 범위:

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

코드 복사 코드는 다음과 같습니다.

var f = 함수 사실(x) {
(x                       1을 반환합니다.
~ ~                                                                              x*fact(x-1) 반환;
                  };
// 잡히지 않은 ReferenceError: 사실이 정의되지 않았습니다

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


위 내용은 이 글의 전체 내용입니다. 모두 마음에 드셨으면 좋겠습니다.

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