>웹 프론트엔드 >JS 튜토리얼 >JavaScript의 즉시 실행 기능 예제에 대한 자세한 설명

JavaScript의 즉시 실행 기능 예제에 대한 자세한 설명

小云云
小云云원래의
2017-12-09 13:39:111719검색

Javascript는 다른 프로그래밍 언어에 비해 상대적으로 캐주얼하기 때문에 JavaScript 코드에는 온갖 이상한 쓰기 방법이 가득하고 때로는 혼란스러울 수도 있습니다. 물론 다양한 쓰기 방법을 이해할 수 있다는 것은 자바스크립트의 특성을 더 깊이 이해하는 것이기도 합니다. 자바스크립트 언어. 이번 글에서는 자바스크립트의 즉시 실행 기능에 대한 관련 정보를 주로 소개하겠습니다. 도움이 되셨으면 좋겠습니다.

Foreword

js 실행 함수를 사용하면 함수가 생성된 후 즉시 실행될 수 있습니다. js 실행 함수 즉시 모드는 함수를 정의한 후 즉시 실행할 수 있도록 하는 구문입니다. 생성 직후 실행되는 함수 표현식(명명 또는 익명)입니다.

( function(){…} )() 및 ( function (){…} () )은 함수를 즉시 실행하기 위해 JavaScript 함수를 작성하는 두 가지 일반적인 방법입니다. 처음에는 괄호로 묶인 익명 함수인 줄 알았습니다. 그리고 마지막에 괄호를 추가했는데, 결국 함수를 정의한 직후에 실행한다는 목적을 달성하게 되었는데, 나중에 괄호를 추가한 이유가 사실이 아닌 것으로 밝혀졌습니다.

아래에서는 할 말이 많지 않으니, 자세한 소개를 살펴보겠습니다.

보통 우리는 다음과 같은 방식으로 함수를 선언합니다:

// 声明函数f1
function f1() {
 console.log("f1");
}
// 通过()来调用此函数
f1();


//一个匿名函数的函数表达式,被赋值给变量f2:
var f2 = function() {
 console.log("f2");
}
//通过()来调用此函数
f2();


//一个命名为f3的函数的函数表达式(这里的函数名可以随意命名,可以不必和变量f3重名),被赋值给变量f3:
var f3 = function f3() {
 console.log("f3");
}
//通过()来调用此函数
f3();

일부 사용자 정의 컨트롤을 본 경우 대부분 다음과 같은 작성 방식을 따른다는 것을 알 수 있습니다.

(function() {
 "
 // 这里开始写功能需求
 })();

이것은 우리가 종종 즉시 실행 함수(IIFE)라고 부르는 것입니다. 이름에서 알 수 있듯이 이 함수는 함수 본문을 즉시 실행하며 이를 적극적으로 호출할 필요가 없다는 의미입니다. 일반적으로 우리는 익명 함수에만 IIFE를 사용합니다. 이를 수행하는 데는 두 가지 목적이 있습니다. 两 하나는 함수 이름을 지정하지 않고 전역 변수 오염을 방지하는 것입니다.


두 번째는 IIFE 내부에 IIFE의 별도 범위를 형성할 수 있다는 것입니다. 밖에서 읽어보세요.


이 두 문장을 이해할 수 없다면 IIFE의 작동 원리부터 시작해 보세요.


IIFE는 일반적으로 익명 함수에 사용되므로 여기서는 간단한 익명 함수를 예로 사용합니다.

var f = function(){
 console.log("f");
}
f();

여기서 f는 이 익명 함수의 참조 변수일 뿐이므로 f() 이후 can call this function, f를 함수 자체로 바꿀 수 있습니까?

function(){
 console.log("f"); 
}();

실행 후 다음 결과를 얻습니다.

Uncaught SyntaxError: Unexpected token (

이 오류의 원인은 Javascript 엔진이 function 키워드는 뒤에 함수 선언문이 있는 것으로 간주하고 괄호로 끝나서는 안 됩니다. 해결책은 괄호 앞의 부분이 함수 정의 문이 아니라 연산이 가능한 표현식임을 엔진에 알리는 것입니다. 함수 선언과 함수 표현식의 차이점은 다음과 같습니다.

1. 즉, 우리는 일반적으로 함수를 선언하기 위해 x(){} 함수를 사용합니다. school 다음과 같이 표현식이 먼저 실행됩니다.


function myFunction () { /* logic here */ }

사실 JavaScript 엔진은 function 키워드를 보면 함수 선언문이라고 생각합니다. 따라서 Javascript 엔진이 괄호를 먼저 확인하면 괄호는 어떻게 되나요?

var myFunction = function () { /* logic here */ };
var myObj = {
 myFunction: function () { /* logic here */ }
};

함수가 성공적으로 실행되었습니다.

1+(2+3) //这里先运行小括号里面的内容没有意见撒

이 경우 Javascript 엔진은 이것이 표현식이라고 생각합니다. , 물론, 자바스크립트 엔진은 이것을 표현식이라고 생각해야 합니다. 이 표현식을 사용하는 방법은 다양합니다.

//用小括号把函数包裹起来
(function(){
  console.log("f");  
})();

이전 질문으로 돌아가서, 왜 IIFE는 전역 변수 오염을 방지합니다. 다른 사람이 작성한 jquery 플러그인을 본 경우 일반적으로 다음과 유사한 코드가 있습니다.

f //控制台输出

여기서 jquery는 실제로 익명 함수의 매개변수입니다. 익명 함수를 호출하면 f()를 사용하므로 익명 매개변수는 f(args)입니다. 여기서 jquery가 매개변수로 함수에 전달되면 형식 매개변수 $는 내부에서 사용될 때 외부 환경에 영향을 주지 않습니다. 일부 플러그인은 $ 한정자를 사용하기 때문에 이 함수 내에서 원하는 모든 작업을 수행할 수 있습니다.

관련 권장 사항:

JS의 즉시 실행 기능

JavaScript_javascript 기술에서 즉시 실행 함수를 작성하는 세 가지 방법

JavaScript_javascript 기술의 즉시 실행 함수 표현식 소개

위 내용은 JavaScript의 즉시 실행 기능 예제에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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