ES6 최상위 객체, 글로벌 객체 인스턴스 분석
최상위 객체
최상위 객체, 브라우저 환경에서는 window 객체, Node에서는 글로벌 객체를 가리킵니다.ES5 이전에는 최상위 객체의 속성과 글로벌 변수가 동일했습니다.
window.a = 1;
a // 1
a = 2;
window.a // 2
위의 코드에서 맨 윗부분 대상의 속성 값과 전역 변수의 값은 같은 일이다.
ES6 규정,
var
명령 및function
명령 성명의 전역 변수는 여전히 맨 윗부분 대상의 속성이다let
명령,const
명령,class
명령 선언의 글로벌 변수이며 최상위 객체의 속성에 속하지 않습니다.즉, ES6부터 글로벌 변수가 최상위 객체의 속성과 단계적으로 연결됩니다.
var a = 1;
// Node REPL , global.a
// , this.a
window.a // 1
let b = 1;
window.b // undefined
글로벌 객체
ES5의 최상위 대상은 그 자체도 문제이다. 왜냐하면 각종 실현 안에서 통일되지 않기 때문이다.
1. 브라우저에서 맨 윗부분의 대상은 윈도우지만 노드와 웹 워커는 윈도우가 없습니다
2. 브라우저와 웹 워커 안에서self도 맨 윗부분 대상을 가리키지만 Node에self가 없습니다.
3. Node의 최상위 객체는 글로벌이지만 다른 환경에서는 지원되지 않습니다.
같은 코드는 각종 환경에서 최상위 대상을 얻기 위해 현재는this변수를 사용하지만 한계가 있다.모든 상황에서 최상위 대상을 찾을 수 있는 방법을 찾기가 매우 어렵다.다음은 두 가지 겨우 사용할 수 있는 방법이다.
// 1
(typeof window !== 'undefined' ? window : (typeof process === 'object' && typeof require === 'function' && typeof global === 'object') ? global : this);
// 2
var getGlobal = function (){
if(typeof self !== 'undefined'){return self;}
if(typeof window !== 'undefined'){return window;}
if(typeof global !== 'undefined'){return global;}
throw new Error('unable to locate global object');
};
언어 표준 차원에서 글로벌을 정상 대상으로 도입하자는 제안이 나왔다.즉 모든 환경에서 글로벌은 존재하고 이를 향해 맨 윗부분의 대상을 얻을 수 있다는 것이다.
// CommonJS
var global = require('system.global')();
// ES6
import getGlobal from 'system.global';
const global = getGlobal();
위의 코드는 상위 대상을 변수 글로벌에 넣습니다
JavaScript에 관한 더 많은 내용은 본 사이트의 주제를 보실 수 있습니다.,,,,,,,,,,,,
이 문서가 JavaScript 프로그램 설계에 도움이 되었으면 합니다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.