분류 전체보기 122

모던 자바스크립트 40. 이벤트(1)

1. 이벤트 드리븐 프로그래밍브라우저는 클릭, 마우스 이동 등 처리해야 할 특정 사건이 발생하면 이를 감지하여 이벤트를 발생시킨다.이벤트가 발생했을 때 호출될 함수를 이벤트 핸들러라고 한다.이벤트가 발생했을 때 브라우저에게 이벤트 핸들러의 호출을 위임하는 것을 이벤트 핸들러 등록이라고 한다.프로그램의 흐름을 이벤트 중심으로 제어하는 프로그래밍 방식을 이벤트 드리븐 프로그래밍이라고 한다. 2. 이벤트 타입이벤트 타입이란 이벤트의 종류를 나타내는 문자열을 의미한다.1. 마우스 이벤트 2. 키보드 이벤트 3. 포커스 이벤트focusin, focusout 이벤트는 addEventListener 메소드 방식을 사용해 등록해야 한다.(다른 방식으로 등록하는 경우 크롬, 사파리에서 정상 작동 X. 등록 방식에 대해선..

모던 자바스크립트 39. DOM(1)

브라우저 렌더링 엔진은 HTML 문서를 파싱하여 브라우저가 이해할 수 있는 자료구조인 DOM을 생성한다.DOM(Document Object Model)은 HTML 문서의 계층적 구조와 정보를 표현하며 이를 제어할 수 있는 API, 즉 프로퍼티와 메소드를 제공하는 트리자료구조이다.1. 노드1. HTML 요소와 노드 객체HTML 요소는 HTML 문서를 구성하는 개별적인 요소를 의미한다. 이 HTML 요소는 렌더링 엔진에 의해 파싱되어 DOM을 구성하는 요소 노드 객체로 변환된다.HTML 요소의 어트리뷰트 → 어트리뷰트 노드 HTML 요소의 텍스트 콘텐츠 → 텍스트 노드HTML 문서는 요소들의 집합으로 이루어지며, HTML 요소는 중첩 관계를 갖는다. 중첩 관계라 함은 HTML의 콘텐츠 영역(시작 태그와 종료..

모던 자바스크립트 37. Set과 Map

JavaScript의 Set과 Map은 ES6에서 도입된 컬렉션 객체다. Set은 중복되지 않는 유일한 값을 저장하고, Map은 키-값 쌍을 저장한다.1. SetSet은 중복되지 않는 유일한 값들의 집합이다.Set 객체는 배열과 유사하지만 다음과 같은 차이가 있다.Set은 수학적 집합을 구현하기 위한 자료구조다. 따라서 Set을 통해 교집합, 합집합, 차집합, 여집합 등을 구현할 수 있다. 1. Set 객체의 생성Set 객체는 Set 생성자 함수(new Set())로 생성한다. Set 생성자 함수에 인수를 전달하지 않으면 빈 Set 객체가 생성된다.const set1 = new Set();console.log(set1); // ✅ Set(0) {};Set 생성자 함수는 이터러블을 인수로 전달받아 Set..

모던 자바스크립트 36. 디스트럭처링 할당

'구조 분해 할당'이라고도 하는 디스트럭처링 할당은 ES6에서 도입된 JavaScript 문법으로, 구조화된 배열과 같은 이터러블 또는 객체를 destructuring(비구조화, 구조 파괴)하여 1개 이상의 변수에 개별적으로 할당하는 것을 말한다. 이는 배열이나 객체의 값을 쉽게 추출하여 변수에 할당할 수 있게 하여 코드의 가독성을 높이고, 더 간결하게 작성할 수 있게 도와준다. 1. 배열 디스트럭처링 할당배열의 요소를 변수에 할당하고자 할 때 사용한다.배열 디스트럭처링 할당 대상(우측)은 이터러블이어야 하며, 형태는 배열 리터럴이어야 한다.배열 디스트럭처링 할당 기준은 배열의 인덱스 즉, 배열 내 요소의 순서대로이다.// 배열 리터럴로 생성된 배열을 arr에 할당const arr = [1, 2, 3, ..

모던 자바스크립트 33. 7번째 데이터 타입 Symbol

심벌Symbol은 ES6부터 도입된 7번째 데이터 타입이다. 변경 불가능한 원시 타입의 값이며 다른 값과 중복되지 않는 유일무이한 값이다.따라서 이름 충돌 위험이 없는 프로퍼티 키를 만들기 위해 사용된다. 심벌 값의 생성1. Symbol 함수심벌 값은 Symbol 함수를 호출하여 생성한다.다른 원시값은 리터럴 표기법을 통해 값을 생성할 수 있지만 심벌 값은 Symbol 함수를 호출하여 생성해야 한다. Symbol 함수는 new 연산자와 함께 호출하지 않는다.(=Constructor X =인스턴스 생성 X)이 때 Symbol 함수를 통해 생성된 심벌 값은 외부로 노출되지 않아 확인 할 수 없으며, 다른 값과 절대 중복되지 않는다.심벌 값도 다른 데이터 타입처럼 객체처럼 접근하면 암묵적으로 래퍼 객체를 생성..

모던 자바스크립트 32. String

표준 빌트인 객체인 String은 원시 타입인 문자열을 다룰 때 유용한 프로퍼티와 메소드를 제공한다.또한 생성자 함수 객체이다. 따라서 new 연산자와 함께 호출하여 String 인스턴스를 생성할 수 있다. length 프로퍼티length 프로퍼티는 문자열의 문자 개수를 반환한다.앞에서 배웠듯 string 래퍼 객체는 유사 배열 객체이므로, 인덱스를 나타내는 숫자를 프로퍼티 키로, 각 문자를 프로퍼티 값으로 갖는다.  String 메소드배열에는 원본 배열을 직접 변경하는 메소드와 새로운 배열을 생성하여 반환하는 메소드가 있다.하지만 String 객체에는 유사배열객체일지라도 원본 String 래퍼 객체를 직접 변경하는 메소드는 존재하지 않고,늘 새로운 문자열을 반환한다. 문자열은 변경 불가능한 원시 값이므..

모던 자바스크립트 30. Date

표준 빌트인 객체인 Date는 날짜와 시간을 위한 메소드를 제공하는 빌트인 객체이며 생성자 함수이다.'현재 날짜와 시간'이라 함은 자바스크립트 코드가 실행된 시스템의 시계에 의해 결정된다.따라서 한국은 KST(한국표준시, UTC+9시간)으로 표시된다. 1. Date 생성자 함수Date는 생성자 함수이다.생성자 함수 Date로 생성한 Date 객체는 내부적으로 날짜와 시간을 나타내는 정수값을 갖는다.이 정수값은 1970년 1월 1일 00:00:00(UTC)을 기점으로 Date 객체가 나타내는 날짜와 시간까지의 밀리초이며, 이를 타임스탬프라고 한다. 즉, 생성자 함수 Date로 생성한 Date 객체는 내부적으로 타임스탬프를 반환한다고 할 수 있다. 1) new Date()Date 생성자 함수를 인수 없이 ..

모던 자바스크립트 26. ES6 함수의 추가 기능

ES6 이전의 함수는 일반 함수로도 호출할 수 있고, 생성자 함수로서 호출할 수도 있고, 메소드로 호출할 수도 있었다.다시 말해 ES6 이전의 모든 함수는 callable이면서 constructor이다. 즉, 사용 목적을 구분하지 않고 사용되었다.하지만 이는 실수를 유발할 수 있고 성능면에서도 손해이다. 따라서 ES6부터는 함수를 사용 목적에 따라 1.일반함수 2.메소드 3.화살표함수 세 가지 종류로 구분하기 시작했다.일반 함수는 함수 선언문이나 함수 표현식으로 정의한 함수를 말하며, 이는 ES6 이전과 차이가 없다.하지만 메소드와 화살표 함수는 ES6 이전과 명확한 차이가 있어서 비교하여 살펴 볼 필요가 있다.ES6 함수의 구분constructorprototypesuperarguments일반 함수OOX..

모던 자바스크립트 24. 클로저

MDN에서는 클로저를 “함수와 그 함수가 선언된 렉시컬 환경과의 조합”이라고 정의하고 있다. “함수가 선언된 렉시컬 환경”이 클로저를 이해하기 위한 핵심 키워드이므로 먼저 알아봐야한다. 렉시컬 스코프자바스크립트 엔진은 함수를 어디에 정의했는지에 따라 상위 스코프를 결정한다. 이를 렉시컬 스코프(정적 스코프)라고 한다.실행 컨텍스트 파트에서 공부했듯 ‘스코프’란 실행 컨텍스트의 렉시컬 환경이다.이 렉시컬 환경은 자신의 “외부 렉시컬 환경에 대한 참조”를 통해 상위 렉시컬 환경과 연결된다.이 원리로 이루어지는 것이 바로 스코프 체인인 것. 따라서 함수의 상위 스코프를 결정한다는 것은 렉시컬 환경의 외부 렉시컬 환경에 대한 참조에 저장할 참조값을 결정한다는 것과 같다.렉시컬 환경의 외부 렉시컬 환경에 대한 참..