JS 범위 및 범위 체인에 대한 자세한 설명_기본 지식
(1) 범위
변수의 범위는 프로그램 소스 코드에 정의된 변수의 영역입니다.
1. JS에서는 어휘 범위를 사용합니다
함수 내에서 선언되지 않은 변수(함수에서 var가 생략된 경우에도 전역 변수로 간주됨)를 전역 변수(전역 범위)라고 합니다.
함수 내에서 선언된 변수는 함수 범위를 가지며 지역 변수입니다
로컬 변수는 전역 변수보다 우선순위가 높습니다
var name="one";
함수 테스트(){
var name="two";
console.log(이름); //두개
}
테스트();
함수에서 var를 생략하면 실제로 전역 변수에 다시 작성되었기 때문에 전역 변수에 영향을 미칩니다.
var name="one";
함수 테스트(){
이름="두";
}
테스트();
console.log(이름); //두개
함수 범위, 즉 함수는 범위의 기본 단위입니다. js에는 if for 등 c/c와 같은 블록 수준 범위가 없습니다.
함수 테스트(){
for(var i=0;i If(i==5){
var name = "one";
}
}
console.log(이름); //하나
}
test(); //함수 수준의 범위이기 때문에 name="one"에 접근할 수 있습니다
물론 js에서도 고차 함수가 사용되는데, 이는 실제로 중첩 함수로 이해될 수 있습니다
함수 테스트1(){
var 이름 = "하나";
반환 함수(){
console.log(이름);
}
}
test1()();
test1() 후에 외부 함수가 호출되고 내부 함수가 반환됩니다. 그런 다음 continue()가 호출되고 이에 따라 내부 함수가 실행되므로 "one"
이 출력됩니다.중첩 함수에는 클로저가 포함되며 이에 대해서는 나중에 설명하겠습니다. 여기서 내부 함수는 범위 체인 메커니즘과 관련된 외부 함수에 선언된 변수 이름에 액세스할 수 있습니다.
2.JS에서 미리 선언
js의 함수 범위는 함수 내에서 선언된 모든 변수가 함수 본문 내에서 항상 표시된다는 의미입니다. 게다가 변수가 선언되기 전에도 사용할 수 있는 상황을 호이스팅(hoisting)이라고 합니다
팁: js 엔진이 미리 컴파일되면 코드가 실행되기 전에 미리 선언되는 현상이 발생합니다
예를 들어
var name="one";
함수 테스트(){
console.log(이름); //정의되지 않음
var name="two";
console.log(이름); //두개
}
테스트();
위의 내용은 다음과 같은 효과를 얻습니다
var name="one";
함수 테스트(){
변수 이름;
console.log(이름); //정의되지 않음
이름="두";
console.log(이름); //두개
}
테스트();
var를 다시 제거해 보시겠습니까? 전역 변수가 된 함수 내 이름이므로 더 이상 정의되지 않습니다
var name="one";
함수 테스트(){
console.log(이름); //하나
이름="두";
console.log(이름); //두개
}
테스트();
3. 위에서 언급한 매개변수 중 어느 것도 통과되지 않았다는 점에 주목할 필요가 있습니다. 테스트에 매개변수가 있으면 어떻게 되나요?
기능 테스트(이름){
console.log(이름); //하나
이름="두";
console.log(이름); //두개
}
var 이름 = "하나";
테스트(이름);
console.log(이름); // 하나
앞서 언급했듯이 기본 유형은 값으로 전달되므로 테스트에 전달된 이름은 실제로는 함수가 반환된 후 지워집니다.
함수의 name="two"가 두 개의 독립적인 이름이기 때문에 전역 이름을 변경한다고 생각하지 마세요
(2) 스코프체인
위에 언급된 고급 기능에는 범위 체인이 포함됩니다
함수 테스트1(){
var 이름 = "하나";
반환 함수(){
console.log(이름);
}
}
test1()();
1. 설명을 위해 큰 단락을 소개합니다.
JavaScript 코드(전역 코드 또는 함수)의 각 부분에는 이와 관련된 범위 체인이 있습니다.
이 범위 체인은 개체의 목록 또는 연결된 목록입니다. 이 개체 그룹은 이 코드에서 "범위 내" 변수를 정의합니다.
js가 변수 x의 값을 찾아야 하는 경우(이 프로세스를 변수 확인이라고 함) 체인의 첫 번째 개체에서 시작됩니다. 이 개체에 x라는 속성이 있는 경우 이 속성의 값은 다음과 같습니다. 첫 번째 객체에 x라는 속성이 없으면 js는 체인에서 다음 객체를 계속 검색합니다. 두 번째 객체에 여전히 x라는 속성이 없으면 계속해서 다음 객체를 찾습니다. 범위 체인의 개체에 x 속성이 포함되어 있지 않으면 x가 이 코드의 범위 체인에 존재하지 않는 것으로 간주되어 결국 ReferenceError 예외가 발생합니다.
2. 스코프 체인 예시:
js의 최상위 코드(즉, 함수 정의가 포함되지 않은 코드)에서 범위 체인은 전역 개체로 구성됩니다.
중첩이 포함되지 않은 함수 본문에는 범위 체인에 두 개의 개체가 있습니다. 첫 번째는 함수 매개변수와 지역 변수를 정의하는 개체이고 두 번째는 전역 개체입니다.
중첩된 함수 본문에는 범위에 객체가 3개 이상 있습니다.
3. 스코프 체인 생성 규칙:
함수를 정의하면(정의되면 시작됩니다) 실제로 범위 체인을 저장합니다.
이 함수가 호출되면 매개변수나 지역 변수를 저장할 새 개체를 만들고 해당 범위 체인에 개체를 추가하며 "체인"을 호출하는 함수에 대한 새롭고 긴 표현을 만듭니다.
중첩 함수의 경우 상황이 다시 변경됩니다. 외부 함수가 호출될 때마다 내부 함수가 다시 정의됩니다. 외부 함수가 호출될 때마다 범위 체인이 다르기 때문입니다. 내부 함수는 정의될 때마다 미묘하게 달라야 합니다. 내부 함수의 코드는 외부 함수가 호출될 때마다 동일하며 이 코드와 관련된 범위 체인도 다릅니다.
(tip: 위의 3가지 사항을 잘 이해하고 기억해 두세요. 본인의 말로 말하는 것이 가장 좋으며, 그렇지 않으면 면접관이 직접 물어볼 것이기 때문에 외워야 합니다: 스코프 체인에 대해 설명해 주세요.. .)
범위 연결의 실제 예:
var name="one";
함수 테스트(){
var name="two";
함수 테스트1(){
var name="세";
console.log(이름); //세개
}
함수 test2(){
console.log(이름); // 2개
}
test1();
test2();
}
테스트();
위는 중첩된 함수이므로 범위 체인에 세 개의 객체가 있어야 합니다
그런 다음 호출할 때 이름 값을 찾아야 하며 범위 체인에서
test1()이 성공적으로 호출되면 test1()->test()-> 전역 객체 창 순서가 됩니다. test1()에서 name의 값 3을 찾았으므로 검색이 완료되고
test1()이 성공적으로 호출되면 test2()->test()->전역 개체 창 순서가 됩니다. test2()에서는 name 값을 찾을 수 없으므로 test( ) 이름의 값이 2이면 검색이 완료되고이 반환됩니다.
또 다른 예는 우리가 면접 중에 실수를 하거나 속이는 일이 잦다는 것입니다.
http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
http://www.w3.org/1999/xhtml">
머리>
본문>

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











typedef struct는 C 언어에서 구조 사용을 단순화하기 위해 구조 유형 별칭을 만드는 데 사용됩니다. 구조 별칭을 지정하여 기존 구조에 새 데이터 유형의 별칭을 지정합니다. 향상된 가독성, 코드 재사용 및 유형 확인 등의 이점이 있습니다. 참고: 별칭을 사용하기 전에 구조를 정의해야 합니다. 별칭은 프로그램에서 고유해야 하며 선언된 범위 내에서만 유효해야 합니다.

Java의 변수 예상 값 예외는 변수 초기화, null 값 사용, 지역 변수 범위 파악을 통해 해결할 수 있습니다.

JavaScript 클로저의 장점에는 변수 범위 유지, 모듈식 코드 활성화, 실행 지연 및 이벤트 처리가 포함됩니다. 단점에는 메모리 누수, 복잡성 증가, 성능 오버헤드 및 범위 체인 효과가 포함됩니다.

C++의 #include 전처리기 지시문은 외부 소스 파일의 내용을 현재 소스 파일에 삽입하고 해당 내용을 현재 소스 파일의 해당 위치에 복사합니다. 표준 입출력 함수를 포함하기 위한 #include <iostream>과 같이 코드에 필요한 선언이 포함된 헤더 파일을 포함하는 데 주로 사용됩니다.

C++ 스마트 포인터의 수명 주기: 생성: 스마트 포인터는 메모리가 할당될 때 생성됩니다. 소유권 이전: 이동 작업을 통해 소유권을 이전합니다. 해제: 스마트 포인터가 범위를 벗어나거나 명시적으로 해제되면 메모리가 해제됩니다. 객체 소멸: 가리키는 객체가 소멸되면 스마트 포인터는 유효하지 않은 포인터가 됩니다.

할 수 있다. C++에서는 중첩된 함수 정의 및 호출을 허용합니다. 외부 함수는 내장 함수를 정의할 수 있고 내부 함수는 범위 내에서 직접 호출할 수 있습니다. 중첩된 함수는 캡슐화, 재사용성 및 범위 제어를 향상시킵니다. 그러나 내부 함수는 외부 함수의 로컬 변수에 직접 액세스할 수 없으며 반환 값 유형은 외부 함수 선언과 일치해야 합니다.

Vue에서는 let과 var 사이에 변수를 선언할 때 범위에 차이가 있습니다. 범위: var에는 전역 범위가 있고 let에는 블록 수준 범위가 있습니다. 블록 수준 범위: var는 블록 수준 범위를 생성하지 않으며, 블록 수준 범위를 생성합니다. 재선언: var는 동일한 범위에 있는 변수의 재선언을 허용하지만 let은 허용하지 않습니다.

JavaScript에서 이 포인팅 유형은 다음을 포함합니다: 1. 전역 객체, 2. 함수 호출, 3. 생성자 호출, 5. 화살표 함수(외부 상속). 또한, 바인딩(), call() 및 apply() 메서드를 사용하여 이것이 가리키는 내용을 명시적으로 설정할 수 있습니다.
