728x90
반응형

Study/JavaScript 14

모던 자바스크립트 Deep Dive - 9장 타입 변환과 단축 평가

📌 목차 - 타입 변환 - 암묵적 타입 변환 - 명시적 타입 변환 - 단축 평가 💡 타입 변환 기존 원시 값을 사용하여 다른 타입의 새로운 원시 값을 생성하는 것이다. 💡 암묵적 타입 변환 개발자의 의도와는 상관없이 표현식을 평가하는 도중에 자바스크립트 엔진에 의해 암묵적으로 타입이 자동 변환되는 것을 암묵적 타입 변환이라고 한다. 또는 타입 강제 변환이라고 한다. 자바스크립트 엔진은 연산자의 본래 성격과 목적을 기준으로 최대한 에러가 나지 않는 방향으로 타입을 암묵적으로 변환한다. 1. 문자열 타입으로 변환 아래 예제의 + 는 피연산자 중 하나 이상이 문자열이므로 문자열 연결 연산자로 동작한다. - 코드 문맥에 부합하도록 암묵적 타입 변환을 실행한다. 1 + '234' // "1234" 템플릿 리터럴 ..

Study/JavaScript 2023.06.28

모던 자바스크립트 Deep Dive - 8장 제어문

📌 목차 - 제어문 - 블록문 - 조건문 - 반복문 - break문 - continue문 💡 제어문 제어문(control flow statement)은 조건에 따라 코드 블록을 실행하거나 반복 실행할 경우 사용한다. 일반적인 코드는 위에서 아래적로 순차적으로 실행하지만, 제어문을 사용하면 코드의 실행 흐름을 인위적으로 제어할 수 있다. //제어문 var x = 1; if (x < 3) { x++; } 💡 블록문 블록문(block statement)은 0개 이상의 문을 중괄호로 묶은 것으로, 코드 블록 또는 블록이라고 부른다. 블록문은 하나의 실행 단위로 취급하며, 단독으로 사용하기도 하나 일반적으로 제어문이나 함수를 정의할 경우 사용한다. 문의 끝에는 세미콜론을 붙이는 것이 일반적이지만 블록문은 언제나 ..

Study/JavaScript 2023.06.16

모던 자바스크립트 Deep Dive - 7장 연산자

📌 목차 - 연산자 1. 비교 연산자 2. 삼항 조건 연산자 3. 논리 연산자 4. typeof 연산자 5. 지수 연산자 6. 그외의 연산자 💡 연산자 연산자는 하나 이상의 표현식을 대상으로 산술, 할당, 비교, 논리, 타입 지수 연산 등을 수행해 하나의 값을 만든다. 연산의 대상을 피연산자라 한다. 피연산자는 값으로 평가될 수 있는 표현식이어야 한다. 피연산자와 연산자의 조합으로 이뤄진 표현식도 값으로 평가될 수 있는 표현식이다. 비교 연산자 동등 비교 연산자와 일치 비교 연산자는 좌항과 우항의 피연산자가 같은 값으로 평가되는지 비교해 불리언 값을 반환한다. 역할이 비슷해 보이나 비교하는 엄격성의 정도가 다르다. 동등 비교 == 일치 비교 === 2 == '2' // true 2 === '2' // f..

Study/JavaScript 2023.06.09

모던 자바스크립트 Deep Dive - 6장 데이터 타입

📌 목차 - 데이터 타입 - 원시 타입 - 객체 타입 - 데이터 타입의 필요성 - 동적 타이핑 💡 데이터 타입 데이터 타입이란 값의 종류를 의미하며 자바스크립트의 모든 값은 데이터 타입을 갖는다. 💡 원시 타입 구분 데이터 타입 설명 원시 타입 숫자 타입 숫자, 정수, 실수 구분없이 하나의 숫자 타입만 존재 문자열 타입 문자열 불리언 타입 True, False undefined 타입 var 키워드로 선언된 변수에 암묵적으로 할당되는 값 null 타입 값이 없다는 것을 의도적으로 명시할 때 사용하는 값 심벌 타입 ES6에서 추가된 7번째 타입 객체타입 객체, 함수, 배열 숫자 타입 모든 수를 실수로 처리하며, 정수만 표현하기 위한 데이터 타입이 별도로 존재하지 않는다. 정수로 표시된다 해도 사실은 실수이다..

Study/JavaScript 2023.05.30

모던 자바스크립트 Deep Dive - 5장 표현식과 문

📌 목차 - 값 - 리터럴 - 표현식 - 문 💡 값(value) 표현식(expression)이 평가(evaluate)되어 생성된 결과를 의미한다. var sum = 10 + 20; 위 예제는 10 + 20이 평가되어 30이라는 값이 sum이라는 변수에 할당된 것이다. 앞 챕터(4장)에서 변수는 하나의 값을 저장하기 위해 확보한 메모리 공간 자체 혹은 메모리 공간을 식별하기 위해 붙인 이름이라고 설명했다. 따라서 변수에 할당되는 것을 값이라고 한다. * 평가(evaluate) : 식을 해석해서 값을 생성하거나 참조하는 것을 의미한다. * 표현식(expression) : 값으로 평가될 수 있는 문(statement)이다. 즉, 표현식이 평가되면 새로운 값을 생성하거나 기존값을 참조한다. 💡 리터럴(liter..

Study/JavaScript 2023.05.18

모던 자바스크립트 Deep Dive - 4장 변수

📌 목차 - 변수란? - 식별자란? - 변수 선언 - 변수 호이스팅 - 값의 재할당 - 네이밍 규칙 💡 변수란 하나의 값을 저장하기 위해 확보한 메모리 공간 자체 또는 메모리 공간을 식별하기 위해 붙인 이름을 말한다. 변수 이름을 식별자라고 칭하기도 합니다 💡 식별자란 어떤 값을 구별해서 식별할 수 있는 고유한 이름을 말한다. 메모리 상에 존재하는 어떤 값을 식별할 수 있는 이름은 모두 식별자라 부른다. 식별자 안에 포함되는 것들은 변수, 함수, 클래스 등이 존재한다. 자바스크립트에서는 함수도 값이다 💡 변수 선언 값을 저장하기 위한 메모리 공간을 확보하고, 변수 이름과 확보된 메모리 공간의 주소를 연결하여 값을 저장할 수 있게 준비하는 과정을 의미한다. var, let, const 키워드를 사용해 선언..

Study/JavaScript 2023.05.11

[JavaScript]디바운싱과 쓰로틀링이란?

디바운싱과 쓰로틀링은 웹에서 발생하는 이벤트를 제어하는 프로그래밍 기법입니다. 디바운싱(Debouncing) 연속으로 호출되는 함수들 중에 마지막 호출되는 함수만 실행되도록 하는 것 예시) 엔터를 누르지 않아도 검색 결과가 나오는 검색창을 구현한다고하면 본인이 검색하려는 검색어를 다 입력한 후에 검색 결과가 나오는 것이 일반적일 것입니다. 그렇다면 검색어를 입력하려고 타자를 칠 때마다 타이머를 설정하여, 예를들면 2초 동안 입력이 없으면 입력이 끝난 것으로 간주하여 검색 api를 요청하는 방식으로 구현할 수 있습니다 쓰로틀링(Throttling) 마지막 함수가 호출된 후 일정 시간이 지나기 전에 다시 호출되지 않도록 하는 것 쓰로틀링은 실행 횟수에 제한을 걸기 때문에 대개 성능 문제를 이유로 사용합니다...

Study/JavaScript 2022.06.22

[Javascript] 프로미스(Promise)란?

프로미스(Promise)란? Javascript에서의 Promise란 비동기 처리에 사용되는 객체입니다. 프로미스는 Promise 생성자 함수를 통해 인스턴스화합니다. Promise 생성자 함수는 비동기 작업을 수행할 콜백 함수를 인자로 전달받는데 이 콜백 함수는 resolve와 reject 함수를 인자로 전달받습니다. 서버에서 받아온 데이터들을 화면에 표시할 경우 프로미스를 주로 사용합니다. 프로미스의 생성 // Promise 객체 생성 const promise = new Promise((resolve, reject) => { // 비동기 작업 수행 if (/*조건*/) { // 비동기 작업 성공 resolve('success'); } else { //비동기 작업 실패 reject('fail'); } ..

Study/JavaScript 2022.05.01

[Javascript] 콜백(Callback)이란?

콜백(callback)이란? javascript에서 callback 함수는 다른 함수가 실행을 끝낸 뒤 그 다음에 실행하는 함수를 의미합니다. javascript는 single thread에서 동작하기 때문에 한 번에 한 가지 일만 수행 할 수 있습니다. javascript는 비동기적 방식을 사용하여서 작업들이 순차적으로 실행되어야 하는 경우에는 함수들이 순차적이지 않은 순서로 실행되어 결과 또한 바뀔 수 있습니다. [일반 함수] //일반 함수 function introduceMySelf(name, callback) { console.log(`Hello my name is ${name}`); } introduceMySelf('ujam'); //Hello my name is ujam [callback 함수..

Study/JavaScript 2022.04.22

[JavaScript] 클로저(Closure)란?

클로저(Closure)란? MDN에서는 클로저를 이와 같이 정의합니다. 클로저는 함수와 함수가 선언된 어휘적 환경의 조합이다. 클로저를 이해하려면 자바스크립트가 어떻게 변수의 유효범위를 지정하는지(Lexical scoping)를 먼저 이해해야 한다. 클로저는 함수와 그 함수가 선언됐을 경우 렉시컬 환경(Lexical environment)과의 조합입니다. 정의만 읽어봤을 때는 무슨 뜻인지 잘 와닿지 않았습니다. 예제를 통해서 알아보겠습니다. function outer(){ const name = 'ujam'; function inner(){ console.log(name); } return inner; } var getName = outer(); getName(); //ujam outer 함수는 내부에 ..

Study/JavaScript 2022.04.12
728x90
반응형