익명 함수: 이전 글에서도 언급한 바 있는데, 함수 이름이 없는 함수를 말합니다
function (){ console.log('匿名函数') }
중첩 함수는 어떤가요? 코드를 보세요:
function test (){ var sum = 20; //内嵌函数 demo = function(){ alert(sum); console.log('我是嵌套函数'); } }
코드에서 볼 수 있듯이 함수는 함수 내에 내장되어 있는데, 이를 중첩 함수라고 합니다.
그럼 클로저란 무엇일까요?
별로 할 말이 없습니다. 코드를 보세요.
function demo(){ var num = 0; // 返回一个函数 return function(){ alert( num+1 ); } } //将返回的函数赋值给 add 变量 var add = demo(); // add就是一个闭包 add();
이렇게 보면 중첩 함수이고 상위 범위의 변수에 액세스할 수 있는 한 클로저인 것처럼 느껴집니다. 그렇습니까?
JS에서는 전역 범위와 로컬 범위로 나뉘며 각 기능은 로컬 범위와 동일하다는 것을 알고 있습니다.
마찬가지로 변수도 전역변수와 지역변수로 나누어집니다. 차이점은 무엇입니까?
브라우저에서 전역 범위 개체는 창입니다. 즉, 페이지가 열리자마자 창 개체가 존재한다는 의미입니다.
js에서는 각 함수마다 로컬 범위가 있으며, 함수 실행과 함께 로컬 변수가 생성되고 실행 후에는 소멸됩니다.
전역 변수는 페이지가 닫히지 않는 한 항상 존재합니다. 함수가 실행될 때 파괴되지 않습니다.
그럼 폐쇄와 무슨 관련이 있나요?
"JavaScript Advanced 프로그래밍"이라는 책에서 "스코프 체인"의 개념에 대해 이야기했습니다. 특별한 점은 전역 변수를 함수 내에서 직접 읽을 수 있다는 것입니다.
단, 함수 내부의 변수는 함수 외부에서 읽을 수 없습니다.
즉, 스코프 체인은 올라갈 수만 있고 내려갈 수는 없는 사다리와 같습니다. 이해하기 위해 코드 조각을 살펴보겠습니다.
var name = "window"; var age = 20; dmeo(); function demo(){ var age = 21; console.log(name); // window console.log(age); //21 }
demo() 함수를 실행하면 검색 및 반환을 위해 현재 범위의 변수를 저장하기 위해 전역 범위로 연결되는 체인이 생성됩니다.
console.log( name ) 코드를 실행하면 현재 범위(데모 함수)에 name 변수가 있는지 검색합니다. 현재 범위가 존재하지 않으므로 전역 변수 이름이 위쪽으로 검색되므로 window가 반환됩니다. ;
console.log(age) 코드를 실행하면 현재 범위(데모 함수)에 age 변수가 존재하는지 여부도 검색합니다. 21이 반환됩니다.
메커니즘은 위쪽으로만 읽을 수 있으므로 내부 함수의 변수를 외부에서 어떻게 읽을 수 있는지 질문해 보세요.
방법은 없습니다. 약간만 변경하면 됩니다. 이를 위해서는 클로저 개념을 사용해야 합니다.
function f1(){ var num = 0 ; //定义内部函数 function f2(){ return num + 1; } //返回 f2函数引用 retufn f2; } // bar 变量也指向 f2 函数,在此也是一个闭包 var bar = f1(); //执行 bar(); // 1;
우리는 함수가 실행된 후에 함수의 변수가 소멸된다는 것을 알고 있습니다. 위 코드의 경우 f1() 함수가 실행된 후 f2 함수가 전역 변수에 할당되고 f2 함수의 변수는 f1의 num 변수에 따라 달라집니다. 따라서 f1
의 num 변수는 f1의 기능을 따르지 않습니다. 실행 후 삭제됩니다.
여기서 "Ruan Yifeng"이라는 제목을 빌려 이해를 분석하고 심화했습니다.
링크: 자바스크립트 클로저 학습
var name = "the window"; var obj = { name : 'the obj', getName : function(){ return funciton(){ return this.name; } } } //执行 getName返回的函数 alert(obj.getName()());
호출 함수 분석을 살펴보고 실행을 위해 두 부분으로 나누어 보겠습니다. 먼저 obj.getName()을 살펴보겠습니다. 이때 getName 함수는 obj 객체에 의해 호출되므로 이 값은 obj입니다. 하지만 이번에는 출력하지 않고 함수를 반환합니다.
()를 추가하여 반환된 함수를 실행하지만 반환된 함수는 개체 자체에서 호출되지 않으면 이 값이 창 개체로 승격됩니다. 따라서 출력은 "창"입니다
var name = "the Window"; var obj = { name : "the obj", getName : funciton(){ var that = this; return function(){ return that.name; } } } //执行 getName 返回的函数 alert(obj.getName()());
위 내용은 익명 함수, 중첩 함수, 클로저란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!