🌸02장. 자바스크립트란?

✅2.1 자바스크립트의 탄생

1995년, 웹 브라우저 시장 점유율 90%를 가지고 있던 넷스케이프 커뮤니케이션즈가 웹페이지의 보조적인 기능을 수행하기 위해 브라우저에서 동작하는 경량 프로그래밍언어를 도입하기로 결정 후 브렌던 아이크가 개발하였다.

✅2.2 자바스크립트의 표준화

1996년 8월 마이크로소프트는 자바스크립트 파생버전 "JScript"를 익스플로러 3.0에 탑재했는데, JScript와 자바스크립트가 호환이 완벽히 되지 않아 크로스 브라우징 이슈가 발생했다.

비영리 표준화 기구인 ECMA 인터네셔널에 자바스크립트 표준화를 요청하고, 상표권 문제로 ECMAScript로 명명되었다.

특히, 2015년에 공개된 ECMAScript 6(ECMAScript 2015, ES6)let/const 키워드, 화살표 함수, 클래스, 모듈 등과 같이 범용 프로그래밍 언어로서 갖춰야 할 기능들을 대거 도입하는 큰 변화가 있었다.

*@크로스 브라우징 이슈 : 브라우저에 따라 웹 페이지가 정상적으로 동작하지 않는 상태*

주요 ECMAScript 버전별 특징

버전
출시연도
특징

ES1

1997

초판

...

ES3

1999

정규 표현식, try - catch

ES5

2009

HTML5와 함께 출현한 표준안, JSON, strict mode, 접근자 프로퍼티 ,프로퍼티 어트리뷰트 제어 ,향상된 배열 조작 기능(forEach, map, filter, reduce, some, every)

ES6(ECMAScript 2015)

2015

let/const, 클래스, 화살표 함수, 템플릿 리터럴, 디스트럭처링 할당, 스프레드 문법, rest 파라미터, 심벌, 프로미스, Map/Set, 이터러블 , for - of, 제너레이터, Proxy, 모듈 import/export

ES7(ECMAScript 2016)

2016

지수(**)연산자, Array.prototype.includes, String.prototype.includes

ES8(ECMAScript 2017)

2017

async/await, Object 정적 메서드 (Object.values, Object.entriesm Object.getOwnPropertyDescriptors)

...

ES11

2020

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

  • 대부분의 로직은 주로 웹 서버에서 실행

  • 브라우저는 서버로부터 전달받은 HTML과 CSS를 단순히 렌더링하는 수준

@렌더링 : HTML, CSS, Javascript로 작성된 문서를 해석해서 브라우저에 시각적으로 출력하는 것*

  • 이전의 웹페이지 완전한 HTML 코드(html 태그로 시작하고 끝나는 코드)를 서버로부터 전송받아 웹 페이지 전체를 렌더링 하는 방식으로 동작하였다.

    • 화면 전환 → 서버로부터 새로운 HTML을 전송받아 웹페이지 전체를 리렌더링

    • 변경할 필요 없는 부분까지 리렌더링 → 불필요한 데이터 통신 발생 → 성능 면에서도 불리 → 화면이 순간적으로 깜빡이는 현상이 발생

  • Ajax의 등장 이후 웹페이지 변경할 필요가 없는 부분은 다시 렌더링 하지 않고, 서버로부터 필요한 데이터만 전송받아 변경해야 하는 부분만 한정적으로 렌더링하는 방식이 가능해졌다.

    • 웹 브라우저에서도 데스크톱 애플리케이션과 유사한 빠른 성능과 부드러운 화면 전환이 가능해졌다.

  • Node.js는 다양한 플랫폼에 적용할 수 있지만, 서버 사이드 애플리케이션 개발에 주로 사용되고, 모듈, 파일시스템, HTTP 등 빌트인(built-in, 내장) API를 제공한다.

  • 프론트엔드와 백엔드 영역에서 자바스크립트를 사용할 수 있다는 동형성은 별도의 언어를 학습하기 위한 시간을 덜 수 있고,

  • 비동기 I/O를 지원하며, 단일 스레드 이벤트 루프 기반으로 동작함으로써 요청 처리 성능이 좋다.

  • 따라서, 데이터를 실시간으로 처리하기 위해 I/O가 빈번히 발생하는 SPA(Single Page Application)에 적합하다.

  • 또한, 크로스 플랫폼arrow-up-right을 위한 가장 중요한 언어로 주목받고 있다.

✅2.4 자바스크립트와 ECMAScript

  • 자바스크립트 = 프로그래밍 언어

  • 기본 뼈대는 ECMAScript를 준수하고, 추가로 브라우저가 별도로 지원하는 클라이언트 사이드 Web API(DOM, BOM, Canvas, XMLHttpRequest, fetch, requestAnimationFrame, SVG, Web Storage, Web Component, Web Worker 등)를 아우르는 개념

✅2.5 자바스크립트의 특징

  • 자바스크립트는 웹 브라우저에서 동작하는 유일한 프로그래밍 언어다.

  • 개발자가 별도의 컴파일 작업을 수행하지 않는 인터프리터 언어이다.

  • 명령형, 함수형, 프로토타입 기반 객체지향 프로그래밍을 지원하는 멀티 패러다임 프로그래밍 언어다.

  • 클래스 기반 객체지향 언어보다 효율적이면서 강력한 프로토타입 기반의 객체지향 언어다.

Last updated