본문 바로가기
개발서적/모던 자바스크립트 Deep Dive

자바스크립트란? (모던 자바스크립트 Deep Dive)

by 사과넹 2024. 4. 15.
반응형


2.1 자바스크립트의 탄생

1995년 : 탄생

  • 웹 브라우저 시장의 90%를 점유하는 넷스케이프 커뮤니케이션즈브렌던 아이크
    • 웹페이지의 보조적인 기능을 수행하기 위해 브라우저에서 동작하는 경량 프로그래밍 언어를 개발했고 그것이 자바스크립트이다.
어떤 보조적인 기능? 이 당시 웹페이지는 어떤 기능만 구현할 수 있었을까?

 

1996년 : 명명 변화

  • 3월, 모카
    • 넷스케이프 내비게이터2에 탑재
    • 넷스케이프 커뮤니케이션즈의 웹 브라우저
  • 9월, 라이브스크립트
  • 12월, 자바스크립트

 

2.2 자바스크립트의 표준화

1996년 8월 : 경쟁사 등장

  • 마이크로소프트의 자바스크립트 파생 버전 JScript 등장
    • 인터넷 익스플로러 3.0에 탑재
  • 경쟁사 등장으로 크로스 브라우징 이슈 발생
    • 왜? 브라우저 점유율을 높이기 위해 자사 브라우저에서만 동작하는 기능을 엄청 추가한다.
😂 인터넷 익스플로러가 사라진 지금, 결국 웹 브라우저 싸움에서 마이크로소프트가 졌다는 것이다.

 

1996년 11월 : 표준화 요청

  • 비영리 표준화 기구인 ECMA 인터내셔널에 자바스크립트 표준화 요청
    • 누가? 넷스케이프 커뮤니케이션즈
      • MS와의 개싸움을 그만하고 표준화를 요청한 것은 미래적으로 잘한 일

 

1997년 7월 : ECMAScript

  • ECMA-262
    • 표준화된 자바스크립트 초판 사양 완성
    • 상표권 문제로 ECMAScript로 명명

 

1999년 : ECMAScript3 공개

 

2009년 : ECMAScript5 + HTML5 표준 사양으로 등장

 

2015년 : ECMAScript6

  • 6 업데이트는 범용 프로그래밍 언어로서 갖춰야 할 기능들을 도입했고, 이후 작은 기능들을 추가했다.

 

2.3 자바스크립트 성장의 역사

  • 자바스크립트는 브라우저가 서버로부터 전달받은 HTML과 CSS를 렌더링하는 수준이였다.
  • 즉슨 서버에 의존적이며 말그대로 웹페이지의 보조적인 기능만 수행했다.

 

2.3.1 1999년 : Ajax

  • 자바스크립트를 이용해 서버와 브라우저가 비동기 방식으로 데이터를 교환할 수 있는 통신 기능 등장
  • 기존에는 <html>로 시작해서 </html> 로 끝나는 코드를 서버에서 받아오기 때문에 화면 전환 시, 서버에서 새로 받아와 전체 페이지를 또 렌더링하는 방식 → 화면 깜빡임 현상 발생
  • Ajax는 위의 현상을 해결했다.
    • 변경이 필요한 부분만 서버에서 데이터를 받아 한정적으로 렌더링하는 방식을 구현
  • 2005년, 구글 맵스에서 Ajax의 성공적인 사례를 보여주었다.

 

2.3.2 2006년 : jQuery

  • DOM 제어가 훨씬 수월해졌으며 크로스 브라우징 이슈도 대부분 해결되었다.
  • 기존 자바스크립트보다 학습하기 쉬운 jQuery를 선호하는 개발자가 많아졌다.

 

2.3.3 2008년 : V8 자바스크립트 엔진

  • 구글 맵스를 통해 프로그래밍 언어로써 어느정도 인정 받은 자바스크립트
  • 자바스크립트를 이용해 웹앱을 구축하려는 시도가 많아지며 자바스크립트 엔진의 필요성 대두
  • 구글에서 V8 자바스크립트 엔진 개발
  • 이 계기로 서버에 있던 로직들이 클라이언트로 옮겨졌고, 프론트앤드 영역이 자리를 잡게 되었다.
📄 공유 받은 아티클  https://evan-moon.github.io/2019/06/28/v8-analysis/

 

2.3.4 2009년 : Node.js

  • 라이언 달이 V8 자바스크립트 엔진으로 빌드된 자바스크립트 런타임 환경을 발표
  • 자바스크립트를 브라우저 자바스크립트 엔진으로부터 독립시킨 실행 환경
  • 서버사이드 앱 개발에 주로 사용된다
  • 비동기 I/O를 지원, 단일 스레드 이벤트 루프 기반으로 동작 → 요청 처리 성능이 뛰어남, SPA에 적합, CPU 사용률이 높은 앱은 비추천

 

2.4.5 SPA 프레임워크

  • 변경에 유연하며 확장하기 쉬운 앱 아키텍처 구축을 위해 프레임워크들의 등장
    • Angular, React, Vue.js, Svelte 등
  • CBD방법론을 기반으로하는 SPA가 대중화

 

2.4 자바스크립트와 ECMAScript

  • ECMAScript에서 규정하는 핵심 문법에 맞춰 각 브라우저 제조사들은 브라우저 내장 자바스크립트 엔진을 구현한다.
  • ECMAScript⊂ Javascript
    • Javascript = ECMAScript + 클라이언트 사이드 Web API
    • 클라이언트 사이드 Web API - W3C에서 사양 관리중
관련 문서 : https://developer.mozilla.org/ko/docs/Learn/JavaScript

 

2.5 자바스크립트의 특징

  • 웹 브라우저에서 동작하는 유일한 프로그래밍 언어

기본 문법 → C, Java 유사 self → 프로토타입 기반 상속 scheme → 일급 함수 개념 차용

  • 인터프리터 언어
    • 개발자가 별도 컴파일 진행하지 않아도 됨
    • 모던 자바스크립트 엔진들은 인터프리터와 컴파일러의 장점을 결합해 처리 속도가 느린 인터프리터의 단점을 해결했다.
❗ 인터프리터 언어 vs. 컴파일러 언어
https://velog.io/@ash3767/인터프리터-언어와-컴파일-언어

 

  • 명령형, 함수형, 프로토타입 기반 객체지향 프로그래밍을 지원하는 멀티 패러다임 프로그래밍 언어
    • 정의된 것만 봐도 머리가 아픈 언어
728x90
반응형