차이점: 1. 노드에서는 전역을 가리키지만 브라우저에서는 창을 가리킵니다. 2. 노드는 CommonJS 표준을 사용하는 반면 브라우저는 ES 모듈 표준을 사용합니다. 3. 브라우저의 JS는 DOM을 작동할 수 있습니다. 하지만 노드에서는 그렇지 않습니다. 4. I/O 읽기 및 쓰기 작업이 다릅니다. 5. 모듈 로딩이 다릅니다.
이 튜토리얼의 운영 환경: windows7 시스템, nodejs 버전 12.19.0, DELL G3 컴퓨터.
1. 글로벌 환경에서 이 점은
노드에서는 this가 전역을 가리키고 브라우저에서는 밑줄이 정의된 이유입니다.
var root = typeof self == 'object' && self.self === self && self || typeof global == 'object' && global.global === global && global || this;
그리고 브라우저 창 아래에 경고, 문서, 위치, 기록 등과 같은 많은 API를 캡슐화합니다. 노드 환경에서는 xxx() 또는 window.xxx()를 사용할 수 없습니다. 이러한 API는 브라우저 수준 캡슐화이므로 순수 JavaScript에서는 사용할 수 없습니다. 물론 노드는 많은 노드별 API도 제공합니다.
2. 모듈 표준
Node.js는 CommonJS 모듈 시스템을 사용하며 브라우저에서는 ES 모듈 표준이 구현되는 것을 보기 시작했습니다.
실제로 이는 Node.js에서 일시적으로 require()를 사용하고 브라우저에서 가져오는 것을 의미합니다.
3. DOM 작업
대부분의 경우 브라우저의 js는 DOM을 직접 또는 간접적으로 작동합니다(일부 가상 DOM 라이브러리 및 프레임워크). 브라우저의 코드는 주로 프레젠테이션 계층에서 작동하기 때문입니다. 그러나 노드는 서버 측 기술입니다. 프론트 페이지가 없으므로 노드에서 DOM을 작동하지 않습니다.
4. I/O 읽기 및 쓰기
브라우저와 달리 Nodejs는 더 편리한 구성 요소를 제공하므로 파일을 읽고 써야 합니다. 그리고 브라우저는 (호환성을 보장하기 위해) 페이지에서 로컬 이미지를 직접 열려고 할 경우 많은 문제를 겪습니다(단순한 상대 경로가 아니라고 말하지 마십시오... 그냥 시도해 보면 알게 될 것입니다. 라이브러리 업로드 시 바이너리 스트림이거나 네트워크 주소가 표시됩니다. 그렇지 않으면 누가 js 라이브러리를 구축하겠습니까?) 이 모든 작업은 구성 요소를 사용하여 노드에서 수행됩니다.
5. 모듈 로딩
JavaScript의 특징이 있습니다. 즉, 패키지 참조를 제공하지 않는 네이티브 API는 로딩할 모든 것을 한 번에 실행합니다. 여기서는 클로저 기술에 따라 다릅니다. 사용되는 모든 것이 함께 있고, 분할 및 정복이 없으며 논리나 재사용성이 없습니다. 페이지나 웹사이트가 단순하다면 일부 AMD 및 CMD js 라이브러리(예: requireJS 및 seaJS)를 사용하여 이를 수행할 수 있습니다. 실제로 많은 대규모 웹사이트에서 이 작업을 수행합니다.
CMD 모듈 로딩 API는 nodeJS에서 제공됩니다. seaJS를 사용했다면 빨리 시작해야 합니다.
Node는 우리의 음주 라이브러리를 보다 효과적이고 편리하게 관리할 수 있는 패키지 관리 도구인 npm도 제공합니다.
물론 브라우저의 ES6에도 이 기능이 추가되어 앞으로는 더 좋아질 것이라고 믿습니다. . .
노드 관련 지식을 더 보려면 nodejs 튜토리얼을 방문하세요!
위 내용은 노드 환경과 브라우저 환경의 차이점은 무엇인가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!