javaScript_javascript 스킬의 함수 객체 선언에 대한 자세한 설명
작성 이유 :
일반적으로 js에서 함수를 작성할 때 일반적으로 function fn(){}이라는 기존 방식으로 함수를 선언합니다. 몇몇 훌륭한 플러그인을 읽을 때 필연적으로 var fn = function() {}이 무엇인지 보게 됩니다. 오늘은 캐서롤을 깨고 질문을 던지는 정신으로 이 매혹적인 함수 선언에 대해 이야기해 보겠습니다.
함수 선언
함수 선언 샘플 코드
함수 fn() {
console.log('fn 함수 실행..');
// 코드..
}
이렇게 fn이라는 함수를 선언했는데, 이 함수 위에 호출하면 실행될 것 같나요? 아니면 오류가 보고되나요?
fn(); // 앞서 선언한 fn 함수를 호출합니다
함수 fn() {
console.log('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++에서 함수 포인터는 std::function 템플릿을 통해 함수 객체로 변환될 수 있습니다. std::function을 사용하여 함수 포인터를 함수 객체로 래핑합니다. 함수 객체를 함수 포인터로 변환하려면 std::function::target 멤버 함수를 사용하세요. 이 변환은 이벤트 처리, 함수 콜백 및 일반 알고리즘과 같은 시나리오에서 유용하며 더 큰 유연성과 코드 재사용성을 제공합니다.

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 프로토콜을 기반으로 하는 전이중 통신 프로토콜로 클라이언트와 서버 간의 실시간 양방향 통신을 실현할 수 있습니다. 실시간 온라인 주문 시스템에서는 사용자가 요리를 선택하고 주문을 하면

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

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

STL 함수 개체를 사용하면 재사용성이 향상될 수 있으며 다음 단계가 포함됩니다. 함수 개체 인터페이스 정의(클래스를 만들고 std::unary_function 또는 std::binary_function에서 상속) 오버로드된 연산자()에서 함수 동작을 정의하기 위해 연산자()를 오버로드합니다. 함수 객체를 사용하여 STL 알고리즘(예: std::transform)을 통해 필요한 기능 구현
