1단계. 정의 후: 정의된 각 함수에는 개체 목록에 해당하는 고유 속성 [범위]이 있습니다. 목록의 개체는 내부적으로만 액세스할 수 있습니다.
예: 전역 함수 A를 생성하면 A의 [Scope] 내부 속성에는 하나의 전역 개체(Global Object)만 포함되고, A에서 새 함수 B를 생성하면 B의 [ Scope] 속성에는 두 개의 개체가 포함되어 있으며 함수 A의 활성화 개체 개체가 앞에 있고 전역 개체(Global 개체)가 뒤에 있습니다.
간단히 말하면, 함수의 [Scope] 속성에 있는 개체 목록의 순서는 상위 계층 함수의 활성화 개체 개체, 그 다음 상위 계층, 가장 바깥쪽 전역 개체까지입니다.
Step 2. 실행: 함수가 실행되면 실행 가능한 객체(Execution Object)가 자동으로 생성되어 스코프 체인(Scope Chain)에 바인딩됩니다. 범위 체인은 식별자 확인을 위해 다음 두 단계를 통해 설정됩니다.
먼저 함수 객체 [Scope]의 내부 속성에 있는 객체들을 순서대로 스코프 체인에 복사합니다.
두 번째로, 함수가 실행되면 새로운 활성화 개체 개체가 생성됩니다. 이 개체에는 이에 대한 정의, 매개 변수(인수) 및 지역 변수(이름이 지정된 매개 변수 포함)가 포함됩니다. 스코프 체인 앞.
따라서 범위 체인의 마지막 순서는 이 함수의 활성화 개체, 상위 계층 함수의 활성화 개체, 상위 계층의 활성화 개체, 전역 개체까지입니다.
js 코드 실행 중 식별자를 만나면 식별자 이름을 기준으로 실행 컨텍스트(Execution Context)의 스코프 체인에서 검색됩니다. 범위 체인의 첫 번째 개체(함수의 활성화 개체)부터 시작하여 찾을 수 없는 경우 범위 체인에서 다음 개체를 검색하는 식으로 식별자 정의를 찾을 때까지 계속됩니다. 전역 개체인 범위의 마지막 개체를 검색 후에도 찾을 수 없으면 오류가 발생하고 정의되지 않았다는 메시지가 표시됩니다.
여기에서 파생된 제안:
1. 로컬 변수를 사용해 보세요. 이는 단순히 비공개 속성의 문제가 아닙니다. 검색 시간을 줄일 수 있음을 알 수 있습니다(참고: 일반적으로 여기에는 브라우저 최적화 동작이 포함되지 않습니다).
2. with 문을 사용하지 마세요. 실행 컨텍스트(Execution Context)의 범위 체인을 수정하고 앞에 개체(Variable Object)를 추가하기 때문입니다. try-catch 문의 catch 문 블록에도 마찬가지입니다.