JavaScript 13

[모던 자바스크립트 DeepDive] Js 심화 스터디 week 8

브라우저의 렌더링 과정1. 요청과 응답브라우저 주소창에 URL 입력 시 브라우저가 DNS를 통해 IP 주소 조회함해당 서버로 HTTP 요청 전송함서버는 HTML 문서를 응답으로 반환함브라우저는 HTML 문서 수신 후 렌더링 엔진에 전달함2. HTTP 1.0 과 HTTP 2.0HTTP 1.0: 요청마다 TCP 연결 새로 생성함, 다중 요청 불가능함, 리소스가 많은 페이지에서 성능 저하 발생함HTTP 2.0: 하나의 연결에서 다중 요청 동시 처리 가능함, 헤더 압축과 서버 푸시 지원으로 성능 향상됨3. HTML 파싱과 DOM 생성DOM 생성과정 요약1. 렌더링 엔진이 HTML 문서를 읽고 토큰 단위로 분해함2. 토큰을 객체로 변환하여 노드를 생성(문서 노드, 요소 노드, 어트리뷰트 노드, 텍스트 노드).3...

개발 2025.08.27

[모던 자바스크립트 DeepDive] Js 심화 스터디 week 7

심벌 (Symbol)1. 심벌값의 생성심벌은 ES6에서 도입된 원시 타입 중 하나임Symbol() 함수 호출로 생성함생성된 심벌값은 유일무이함new 연산자 사용 불가심벌값은 문자열로 자동 변환되지 않음const sym1 = Symbol('desc');const sym2 = Symbol('desc');console.log(sym1 === sym2); // false2. 심벌과 상수중복되지 않는 상수 값 생성 시 유용함주로 enum 대체 용도로 사용됨const DIRECTION = { UP: Symbol('up'), DOWN: Symbol('down')};3. 심벌과 프로퍼티 키객체 프로퍼티 키로 심벌 사용 가능함문자열 키와 달리 충돌 위험 없음const key = Symbol('key');const o..

개발 2025.08.27

[모던 자바스크립트 DeepDive] Js 심화 스터디 week 05

자바스크립트의 Strict Mode자바스크립트는 유연한 문법을 제공하는 언어이지만,이로 인해 개발자가 실수하더라도 에러 없이 조용히 넘어가는 경우가 많다.이를 보완하기 위해 ES5부터 도입된 기능이 바로 Strict Mode(엄격 모드)이다.Strict Mode는 더 엄격한 문법과 실행 규칙을 적용하여 잠재적인 버그를 사전에 방지할 수 있게 해준다.1. Strict Mode란?Strict Mode는 자바스크립트 실행을 더 엄격하게 만들어 잠재적인 에러나 비표준 사용을 방지하는 모드이다.'use strict';위 문장을 코드 최상단이나 함수 내부에 작성하면 Strict Mode가 적용된다.주요 특징암묵적 전역 변수 사용 금지읽기 전용 프로퍼티에 값 할당 시 에러삭제 불가능한 프로퍼티 삭제 시 에러this가..

개발 2025.07.28

타입스크립트의 사용 이유와 동작 원리

타입스크립트의 동작 원리에 대해서 알아보기 전, 타입 시스템을 먼저 알아보자. 타입 시스템언어에서 사용할 수 있는 아주 여러가지 값들을 어떤 기준으로 묶어서 타입으로 정할지 결정하고 또 코드의 타입을 언제 검사할지 그리고 어떻게 검사할지 등의 우리가 프로그래밍 언어를 사용할때 타입과 관련해서 지켜야 하는 규칙들을 모아둔 체계. 쉽게 말해서, 타입 시스템은 언어의 타입 관련된 문법 체계. 크게 두 가지로 나눌 수 있다. 정적 타입 시스템 : 코드 실행전에 모든 변수의 타입을 고정적으로 결정한다.동적 타입 시스템 : 코드를 실행하기 전에는 타입을 결정하지 않고 코드를 실행하고 나서 그때 그때마다 유동적으로 변수의 타입을 결정한다. 정적 타입 시스템은 엄격하고 고정적인 시스템이라고 볼 수 있고, 동적 타입 시..

개발 2025.07.23

[모던 자바스크립트 DeepDive] Js 심화 스터디 week 04

프로퍼티 어트리뷰트란..자바스크립트에서 객체는 단순히 키-값 쌍으로 구성된 자료 구조처럼 보이지만, 실제로는 보다 복잡한 구조와 메커니즘을 갖고 있다. 객체의 각 프로퍼티는 내부적으로 숨겨진 메타 정보인 프로퍼티 어트리뷰트를 가지고 있으며, 이 정보에 따라 열거 가능성, 수정 가능성, 삭제 가능성 등이 결정된다.1. 내부 슬롯과 내부 메서드자바스크립트 엔진 내부에서 객체는 내부 슬롯과 내부 메서드를 가진다.이들은 언어 사양에 정의되어 있지만, 직접 접근할 수 없고 대괄호로 표현된 형식으로 나타난다.예: [[Value]], [[Writable]], [[Get]], [[Set]], [[Enumerable]], [[Configurable]]예를 들어, 다음과 같이 선언된 객체 프로퍼티에는 다음과 같은 내부 슬..

개발 2025.07.22

MPA 와 SPA

오늘은 MPA와 SPA가 무엇인지 각각 알아보고, 둘의 차이점을 알아볼 예정이다. MPA (Multi Page Application) 란?사용자 - 브라우저 - 서버는 각각 위와 같은 역할 및 동작을 수행한다. MPA는 사용자가 페이지를 이동할 때마다 서버에서 새로운 HTML 페이지를 받아오는 방식이다.- 전통적인 웹사이트 구조 (ex. 네이버, 다음)- 각 URL마다 실제 HTML 파일이나 서버에서 생성된 HTML 페이지가 존재- 페이지를 이동할 때마다 전체 페이지가 새로 로드 예시 흐름- GET /home → 서버에서 home.html 응답- GET /products → 서버에서 products.html 응답브라우저는 각 요청에 대해 새 HTML 문서를 받아오고, CSS/JS도 다시 요청하게 됨.SP..

개발 2025.07.13

[모던 자바스크립트 DeepDive] Js 심화 스터디 week 03

함수 : 함수는 일련의 과정을 문으로 구현하고 코드 블록으로 감싸서 하나의 실행 단위로 정의한 것.[함수를 사용하는 이유]필요할 때마다 한번 정의해 둔 것을 호출만 하면서 재사용할 수 있는 장점이 있다. 이러한 장점으로 우리는 함수를 사용한다. 그것도 아주 많이. + 코드의 가독성 향상 측면도 아주 크다.[함수 리터럴]함수 리터럴의 구성요소var f = function add(x, y) { return x + y;}- function 키워드- 함수 이름- 매개 변수 목록- 함수 몸체[함수정의]-함수 선언문 : function add(x, y) { return x+y; } 방식- 함수 표현식 : var add = function add(x, y) { return x+y; }; 이렇게 변수에 할당하는 ..

개발 2025.07.13

비동기와 API

오늘은 비동기와 API 에 대해서 알아볼 예정입니다.위 그림은 동기 / 비동기 를 이해하기 가장 유용한 것 같아 첨부하였습니다.동기 예시는 아래와 같습니다.const workA = () => { console.log('workA');};const workB = () => { console.log('workB');};const workC = () => { console.log('workC');};workA();workB();workC();위와 같이 작성한 코드는 호출 순서인 workA(), workB(), workC() 순으로 수행됩니다. 이번에는 자바 스크립트에서 사용하는 비동기 내장함수 setTimeout() 을 수행하여 비동기의 동작 흐름을 알아보겠습니다.const workA = (..

개발 2025.07.09

[모던 자바스크립트 DeepDive] Js 심화 스터디 week 02

목차07 연산자08 제어문09 타입 변환과 단축 평가10 객체 리터럴11 원시 값과 객체의 비교[07 - 연산자]산술연산자 : 수학적 계산으로 새로운 숫자 값 만듦. 산술 연산이 불가하 경우 NaN 반환이항 산술 연산자 : +, -, *, /, %단항 산술 연산자 : ++, --, +(어떠한 효과도 없다), - (음수는 양수로, 양수는 음수로 변환)문자열 연결 연산자 : 문자열a + 문자열b = 문자열ab. 단, 해당 연산은 피연산자 중 하나 이상이 문자열인 경우에만 발생한다. 그 외에는 산술연산자로 동작한다.// true는 산술 연산시 1이라는 값을 갖는다.1 + true; // 2// false 는 산술 연산시 0이라는 값을 갖는다.1 + false; // 1// null은 산술 연산시 0이라는 값을..

개발 2025.07.08

[모던 자바스크립트 DeepDive] Js 심화 스터디 week 01

목차1장 - 프로그래밍2장 - 자바스크립트란?3장 - 자바스크립트 개발 환경과 실행 방법4장 - 변수5장 - 표현식과 문6장 - 데이터 타입 서론은 건너뛰고 주요내용 위주로 정리 예정 [2.2 자바스크립트의 표준화 및 배경] [배경]- 마이크로 소프트는 자바스크립트의 파생 버전인 JScript를 자사 브라우저에서만 동작하는 기능을 추가하기 시작했고 이로인해 크로스 브라우징 이슈가 발생- 표준화된 자바스크립트의 필요성 증가 [표준화] - 1997년 7월 ECMA-262 라는 표준화된 자바스크립트 초판 사양 완성 및 ECMAScript 로 명명 이후 2015년 ECMAScript 6 (ES6) 가 공개되었고 이때 - let / const 키워드- 화살표 함수- 클래스- 모듈위와 같은 기능들이 대거 도입되며..

개발 2025.06.27