자바스크립트 함수 선언과 함수 표현의 차이점 분석_기본지식
일반적으로 js에서 함수를 작성할 때 일반적으로 function fn(){}이라는 기존 방식으로 함수를 선언합니다. 몇몇 훌륭한 플러그인을 읽을 때 필연적으로 var fn = function() {}이 무엇인지 보게 됩니다. 오늘은 캐서롤을 깨고 질문을 던지는 정신으로 이 매혹적인 함수 선언에 대해 이야기해 보겠습니다.
함수 선언
함수 선언 샘플 코드
함수 fn() {
console.log('fn 함수 실행..');
// 코드..
}
이렇게 fn이라는 함수를 선언했는데, 이 함수 위에 호출하면 실행될 것 같나요? 아니면 오류가 보고되나요?
콘솔 출력:
네, 이때 fn 함수를 호출할 수 있습니다. 이유를 요약하면 다음과 같습니다.
요약:
1: 이때 fn 함수는 변수의 결과로, 기본적으로 전역 컨텍스트의 변수에 저장됩니다(window.function 이름으로 확인 가능)
2: 이 메소드는 전역 컨텍스트 단계에 들어갈 때 생성되는 함수 선언입니다. 코드 실행 단계에서 이미 사용 가능합니다. ps: 자바스크립트는 메소드에 들어갈 때마다 컨텍스트 환경(글로벌 → 로컬)을 초기화합니다
3: 변수 객체에 영향을 미칠 수 있음(컨텍스트에 저장된 변수만 해당)
함수 표현
함수 표현 예시 코드
var fn = 함수 () {
console.log('fn 함수 [표현식] 명령문 실행..')
// 코드..
}
이런 방식으로 익명 함수를 선언하고 fn 변수에 대한 참조를 지정합니까?
위와 아래에서 다시 한번 표현식으로 선언한 함수를 호출하면 콘솔에 출력되는 모습을 볼 수 있습니다.
// 콘솔 출력을 명확하게 보기 위해 각 호출 전후에 표시를 하여 가독성을 높였습니다.
console.log('이전 통화가 시작되었습니다..');
fn();
console.log('이전 통화가 종료되었습니다..');
var fn = 함수 () {
console.log('fn 함수 [표현식] 명령문 실행..')
// 코드..
}
console.log('통화가 시작된 후..');
fn();
console.log('통화가 시작된 후..');
콘솔 인쇄 결과:
코드가 실행되고 fn() 함수가 처음 호출되면 다음 메시지가 표시되고, fn은 함수가 아닙니다(fn은 메서드가 아닙니다). 오류가 발생하면 작업이 종료됩니다. 마주쳤다.
이는 fn()이 처음 호출되었을 때 var fn 변수가 전역 객체의 속성으로 존재하지 않고, fn이 참조하는 익명 함수 컨텍스트가 초기화되지 않아 이전 호출이 실패했음을 보여줍니다. .
// 이제 이전 호출 로직을 주석 처리한 다음 콘솔 출력을 살펴봅니다.
// console.log('이전 호출이 시작되었습니다..');
// fn();
// console.log('이전 통화가 종료되었습니다..');
var fn = 함수 () {
console.log('fn 함수 [표현식]이 실행을 선언합니다..')
// 코드..
}
console.log('통화는 나중에 시작됩니다..');
fn(); // 표현식
다음에 호출됩니다. console.log('통화는 나중에 시작됩니다..');
콘솔 인쇄 결과:
표현식 함수 이후에 호출이 가능하다고 볼 수 있는 이유를 정리해볼까요?
요약:
1: 우선 변수 자체가 함수로 존재하는 것이 아니라 익명 함수에 대한 참조입니다(값 유형은 참조가 아닙니다)
2: 코드 실행 단계에서 전역 컨텍스트가 초기화되면 전역 속성으로 존재하지 않으므로 변수 객체의 오염이 발생하지 않습니다
3: 이 유형의 선언은 일반적으로 플러그인 개발에서 일반적이며 클로저에서 콜백 함수에 대한 호출로 사용될 수도 있습니다
그래서 function fn () {}는 var fn = function () {}와 같지 않습니다.
위 내용은 이 기사의 전체 내용입니다. 아이디어가 매우 명확하고 비교도 매우 명확합니다. 친구 여러분, 꼭 읽어보세요

핫 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. 웹소켓 기술

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

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

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

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

JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법, 특정 코드 예제가 필요합니다. 서문: 웹 개발에서는 서버와의 데이터 상호 작용이 종종 포함됩니다. 서버와 통신할 때 반환된 HTTP 상태 코드를 가져와서 작업의 성공 여부를 확인하고 다양한 상태 코드에 따라 해당 처리를 수행해야 하는 경우가 많습니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법과 몇 가지 실용적인 코드 예제를 제공합니다. XMLHttpRequest 사용
