찾다
웹 프론트엔드프런트엔드 Q&A자바스크립트의 기본원리인 스코프체인(그림과 글로 자세히 설명)

이 기사는 JavaScript의 범위 체인에 대한 지식을 제공합니다. 외부 공간은 내부 변수에 액세스할 수 없습니다. 그렇다면 이 기본 규칙을 구현하는 기본 원칙은 무엇입니까? 그것이 당신에게 도움이 될 수 있기를 바랍니다!

자바스크립트의 기본원리인 스코프체인(그림과 글로 자세히 설명)

Scope

1.scope란 무엇입니까

간단히 말하면, 범위(영어:scope)는 일반적으로 이름으로 변수를 찾는 규칙 집합입니다. 이 공간은 폐쇄되어 외부에 영향을 미치지 않습니다. 외부 공간은 내부 공간에 접근할 수 없지만 내부 공간은 이를 감싸는 외부 공간에 접근할 수 있습니다.

2. [[Scopes]] 속성

JavaScript에서 각 함수는 객체에 우리가 접근할 수 있는 속성이 있고, 자유롭게 접근할 수 없는 속성이 있습니다. 그 중 하나는 JavaScript 엔진에서만 읽을 수 있는 속성입니다.

사실 [[scope]]는 우리가 흔히 범위라고 부르는 것으로, 범위 런타임의 컨텍스트 컬렉션을 저장합니다.

여기서는 func.prototype.constructor와 func가 동일한 함수를 가리키므로 여기서는 func

자바스크립트의 기본원리인 스코프체인(그림과 글로 자세히 설명)

3 함수의 프로토타입 객체에 액세스하여 [[Scopes]] 속성을 봅니다. [[scope]]에 저장된 실행 시간 컨텍스트 개체 컬렉션입니다. 이 컬렉션은 체인으로 연결되어 있습니다. 자바스크립트는 스코프 체인을 통해 변수를 검색합니다. 검색 방법은 스코프 체인 상단을 따라 아래쪽으로 쿼리하는 것입니다. (객체는 함수 스코프 체인 내에서 검색됩니다.)

4.변수 찾기 원리 설명

//以如下代码为例说明JavaScript通过作用域链查找变量的原理**
function a() {
  function b() {
      var b = 123;
  }
  var a = 123;
  b();
}
var glob = 100;

1. 전역 함수 a()가 정의되면 스코프 체인은 다음과 같습니다

자바스크립트의 기본원리인 스코프체인(그림과 글로 자세히 설명) 함수의 [[Scopes]] 속성은 스코프 체인 객체를 가리킵니다. 전역 개체를 가리키는 키-값 쌍은 하나만 있습니다. 전역 개체는 전역적으로 액세스할 수 있는 항목, 즉 모든 사람이 액세스할 수 있는 가장 바깥쪽 범위를 저장합니다.

2. 전역 함수 a()가 활성화되어 호출되면 스코프 체인은 다음과 같습니다

자바스크립트의 기본원리인 스코프체인(그림과 글로 자세히 설명)이 때 스코프 체인이 가장 먼저 접근할 수 있는 것은 키-값 쌍입니다. 활성화 객체가 없는 경우 전역 객체에 액세스할 때만

3. 함수 b가 함수 a()에 정의된 경우 b의 범위 체인은 다음과 같습니다

자바스크립트의 기본원리인 스코프체인(그림과 글로 자세히 설명) 정의되었지만 호출되지 않은 경우 b의 스코프 체인은 다음과 같습니다. a는 동일합니다

4. 함수 a()의 b 함수가 활성화되어 호출되면 스코프 체인은 다음과 같습니다

자바스크립트의 기본원리인 스코프체인(그림과 글로 자세히 설명) 스코프 체인은 먼저 함수 b()의 활성화 객체를 가리키고, 검색 변수도 스코프 체인의 순서대로 접근하고, 발견되면 중지됩니다

5. 요약외부 스코프가 불가능한 이유 내부 범위에 대한 액세스는 외부 범위의 범위 체인에 내부 범위의 활성화 개체가 없으므로 내부 범위의 변수에 액세스하는 순서는 범위 체인에 따릅니다. 그렇지 않은 경우 범위 체인을 따라 바깥쪽으로 검색하세요.

관련 권장 사항:

javascript 학습 튜토리얼

위 내용은 자바스크립트의 기본원리인 스코프체인(그림과 글로 자세히 설명)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 掘金에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
React의 생태계의 크기 : 복잡한 풍경 탐색React의 생태계의 크기 : 복잡한 풍경 탐색Apr 28, 2025 am 12:21 AM

Tonavigatereact'scomplexecosystemectically, worldsandlibraries, endegeirstrengthsandweaknesses, andintegrateTheMtoEnhancedEvelopment.StartWithCorereaCtConceptSandusestate, gragratevallystecorecomplexSolutionsormerObxasnee

React가 키를 사용하여 목록 항목을 효율적으로 식별하는 방법React가 키를 사용하여 목록 항목을 효율적으로 식별하는 방법Apr 28, 2025 am 12:20 AM

ReactuseskeyStoefficificificificientifyListItemsByProvingableIdentityToeachelement.1) KeysLACKERACERACTTOTRACKCHANGENLISTSWITHOUTRE-RENDERINGENTIRELIST.2) 선택 ARRAYINDICES.3) 교정 keyUsagesSENTIFORYLATIONTIMPROFFERCANC

React의 키 관련 문제 디버깅 : 문제 식별 및 해결React의 키 관련 문제 디버깅 : 문제 식별 및 해결Apr 28, 2025 am 12:17 AM

KeysinReactareCrucialforopiTizingProcess 및 ManingDynamicListSeffecticaly.tospotandfixkey-RelatedIssues : 1) addUniqueKeyStolistemStoavoidwarningsandperformanceIssues, 2) indainiqueIdentifiers, 3) 보장

React의 편도 데이터 바인딩 : 예측 가능한 데이터 흐름 보장React의 편도 데이터 바인딩 : 예측 가능한 데이터 흐름 보장Apr 28, 2025 am 12:05 AM

React의 일원 데이터 바인딩은 데이터가 모성 구성 요소에서 자식 구성 요소로 흐르는 것을 보장합니다. 1) 데이터는 단일로 흐르고 부모 구성 요소의 상태의 변경 사항은 하위 구성 요소로 전달 될 수 있지만, 하위 구성 요소는 부모 구성 요소의 상태에 직접 영향을 줄 수 없습니다. 2)이 방법은 데이터 흐름의 예측 가능성을 향상시키고 디버깅 및 테스트를 단순화합니다. 3) 제어 된 구성 요소 및 컨텍스트를 사용하여 일방 통행 데이터 스트림을 유지하면서 사용자 상호 작용 및 구성 요소 통신을 처리 할 수 ​​있습니다.

React 구성 요소에서 키를 선택하고 관리하기위한 모범 사례React 구성 요소에서 키를 선택하고 관리하기위한 모범 사례Apr 28, 2025 am 12:01 AM

KeysinReactarecrucialforforforforforficient DomesandReciliation.1) 선택 가능한, 독특하고, 평범한 경비, 같은 시설, 2) fornestedlists, useUniqueysateachlevel.3) 피할 수 없음.

React 응용 프로그램에서 usestate ()로 성능을 최적화합니다React 응용 프로그램에서 usestate ()로 성능을 최적화합니다Apr 27, 2025 am 12:22 AM

usestate () iscrucialforoptimizingReactAppPerformancedUeToitSumneR-RendersandUpdates.tooptimize : 1) useeCallBackTomeMoizeFunctionsandPreventUncessaryre-renders.2) EmployEsemEmeMoforCachingExpensiveComputations.3) BreakStateSmarloBlesmormormormormor

컨텍스트와 usestate ()를 사용하여 구성 요소간에 상태를 공유컨텍스트와 usestate ()를 사용하여 구성 요소간에 상태를 공유Apr 27, 2025 am 12:19 AM

컨텍스트와 usestate를 사용하여 대규모 React 응용 프로그램에서 상태 관리를 단순화 할 수 있으므로 상태를 공유하십시오. 1) 프로포 드릴링을 줄이기, 2) 명확한 코드, 3) 글로벌 상태를 쉽게 관리 할 수 ​​있습니다. 그러나 성능 오버 헤드 및 복잡성을 디버깅하는 데주의를 기울이십시오. 컨텍스트 및 최적화 기술의 합리적인 사용은 응용 프로그램의 효율성과 유지 가능성을 향상시킬 수 있습니다.

반응의 가상 DOM 업데이트에 대한 잘못된 키의 영향반응의 가상 DOM 업데이트에 대한 잘못된 키의 영향Apr 27, 2025 am 12:19 AM

잘못된 키를 사용하면 React Applications에서 성능 문제와 예기치 않은 동작이 발생할 수 있습니다. 1) 키는 목록 항목의 고유 식별자로 가상 DOM을 효율적으로 업데이트하는 데 도움이됩니다. 2) 동일하거나 비 유니 키 키를 사용하면 목록 항목이 재정렬되고 구성 요소 상태가 손실됩니다. 3) 안정적이고 고유 한 식별자를 키로 사용하면 성능을 최적화하고 전체 재 렌더링을 피할 수 있습니다. 4) eslint와 같은 도구를 사용하여 키의 정확성을 확인하십시오. 키를 올바르게 사용하면 효율적이고 안정적인 반응 응용 프로그램이 보장됩니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기