동그란 도그린
[모던 자바스크립트 Deep Dive🦎] 9장 : 타입 변환과 단축 평가 본문
📍 타입 변환
- 타입 변환이란?
- 기존 원시 값을 사용해 다른 타입의 새로운 원시 값을 생성하는 것
- 명시적 타입 변환(타입 캐스팅)
- 개발자가 의도적으로 타입을 변환하는 것
- 암묵적 타입 변환(타입 강제 변환)
- 개발자의 의도와는 관계없이 자바스크립트 엔진에 의해 암묵적으로 타입이 변환되는 것
- 기존 변수 값을 재할당하여 변경하는 것은 아님
- 때로는 명시적 타입 변환보다 가독성 측면에서 더 좋을 수 있음
📍 암묵적 타입 변환
- 문자열 타입으로 변환
- 템플릿 리터럴의 표현식 삽입은 표현식의 평가 결과를 문자열 타입으로 암묵적 타입 변환함
`1 + 1 = ${1+1}` // => "1 + 1 = 2"
// 숫자 타입 0 + '' // => "0" // 불리언 타입 true + '' // => "true" // null 타입 null + '' // => "null" // undefined 타입 undefined + '' // => "undefined" // 심벌 타입 (Symbol()) + '' // => TypeError: cannot convert a Symbol value to a String // 객체 타입 ({}) + '' // => "[Object Object]"
- 숫자 타입으로 변환
- 산술 연산자
- 모든 피연산자는 코드 문맥상 모두 숫자 타입이어야 함
- 피연산자를 숫자 타입으로 변환 불가능할 경우 산술 연산을 수행할 수 없으므로 표현식의 평가 결과가 NaN
- 비교 연산자
- 비교 연산자의 역할은 불리언 값을 만드는 것
- 모든 피연산자가 숫자 타입이어야 함
// 문자열 타입 +'' // => 0 +'0' // => 0 // 불리언 타입 +true // => 1 // null 타입 +null // => 0 // undefined 타입 +undefined // => NaN // 심벌 타입 +Symbol() // => TypeError: Cannot convert a Symbol value to a number // 객체 타입 +{} // => NaN +[] // => 0 +[10,20] // => NaN +(function(){}) // => NaN
- 산술 연산자
- 불리언 타입으로 변환
- 자바스크립트 엔진은 불리언 타입이 아닌 값을 Truthy 값(참으로 평가되는 값)이나 Falsy 값(거짓으로 평가되는 값)으로 구분
- Falsy 값
- false
- undefined
- null
- 0
- -0
- NaN
- ‘’(빈 문자열)
- Truthy 값
- Falsy 값을 제외한 모든 값
📍 명시적 타입 변환
- 명시적으로 타입 변경하는 방법
- 표준 빌트인 생성자 함수(String, Number, Boolean)를 new 연산자 없이 호출하는 방법
- 빌트인 메서드 사용하는 방법 (자바스크립트에서 기본 제공하는 함수, 객체를 생성하기 위한 함수로 new 연산자와 함께 호출)
- 암묵적 타입 변환을 이용하는 방법
- 문자열 타입으로 변환
- String 생성자 함수를 new 연산자 없이 호출하는 방법
- Object.prototype.toString 메서드 사용하는 방법
- 문자열 연결 연산자 이용하는 방법
// 1. String 생성자 함수를 new 연산자 없이 호출하는 방법 // 숫자 타입 -> 문자열 타입 String(1); // => "1" // 불리언 타입 -> 문자열 타입 String(true); // => "true" // 2. Object.prototype.toString 메서드 사용하는 방법 // 숫자 타입 -> 문자열 타입 (1).toString(); // => "1" (NaN).toString(); // => "NaN" // 3. 문자열 연결 연산자 이용하는 방법 // 숫자 타입 -> 문자열 타입 1 + ''; // => "1" // 불리언 타입 -> 문자열 타입 true + ''; // => "true"
- 숫자 타입으로 변환
- Number 생성자 함수를 new 연산자 없이 호출하는 방법
- parselnt, parseFloat 함수를 사용하는 방법 (문자열→숫자만 가능)
- 단항 산술 연산자 이용하는 방법
- 산술 연산자 이용하는 방법
// 1. Number 생성자 함수를 new 연산자 없이 호출하는 방법 // 문자열 타입 -> 숫자 타입 Number('0'); // => 0 // 불리언 타입 -> 숫자 타입 Number(true); // => 1 // 2. parselnt, parseFloat 함수를 사용하는 방법 (문자열→숫자만 가능) // 문자열 타입 -> 숫자 타입 parseInt('0'); // => 0 // 3. + 단항 산술 연산자 이용하는 방법 // 문자열 타입 -> 숫자 타입 +'0'; // => 0 // 불리언 타입 -> 숫자 타입 +true; // => 1 // 4. * 산술 연산자 이용하는 방법 // 문자열 타입 -> 숫자 타입 '0' * 1; // => 0 // 불리언 타입 -> 숫자 타입 true * 1; // => 1
- 불리언 타입으로 변환
- Boolean 생성자 함수를 new 연산자 없이 호출하는 방법
- ! 부정 논리 연산자를 두 번 사용하는 방법
// 1. Boolean 생성자 함수를 new 연산자 없이 호출하는 방법 // 문자열 타입 -> 불리언 타입 Boolean('x'); // => true; // 숫자 타입 -> 불리언 타입 Boolean(0); // => false; // null 타입 -> 불리언 타입 Boolean(null); // => false; // undefined 타입 -> 불리언 타입 Boolean(undefined); // => false; // 객체 타입 -> 불리언 타입 Boolean({}); // => true; Boolean([]); // => true; // 2. ! 부정 논리 연산자를 두 번 사용하는 방법 // 문자열 타입 -> 불리언 타입 !!'x'; // => true // 숫자 타입 -> 불리언 타입 !!0; // => false !!NaN; // => false // null 타입 -> 불리언 타입 !!null; // => false // undefined 타입 -> 불리언 타입 !!undefined // => false // 객체 타입 -> 불리언 타입 !!{}; // => true !![]; // => true
📍 단축 평가
- 표현식을 평가하는 도중에 평가 결과가 확정된 경우 나머지 평가 과정을 생략하는 것
- 논리 연산자를 사용한 단축평가
- 논리합( || ) 또는 논리곱(&&) 연산자 표현식은 언제나 2개의 피연산자 중 어느 한쪽으로 평가됨
단축 평가 표현식 | 평가 결과 |
true || anything | true |
false || anything | anything |
true && anything | anything |
false && anything | false |
📍 옵셔널 체이닝 연산자 (?.)
- 좌항의 피연산자가 null 또는 undefined인 경우 undefined를 반환하고, 그렇지 않으면 우항의 프로퍼티 참조를 이어감
- 좌항의 피연산자가 Falsy 값이라도 null 또는 undefined가 아니면 우항의 프로퍼티 참조를 이어감
- 변수가 null 또는 undefined가 아닌지 확인하고 프로퍼티를 참조할 때 유용
- 이 연산자가 도입되기 전에는 논리연산자 &&를 사용한 단축 평가를 통해 변수가 null/undefined인지 확인했으나, &&를 사용하면 0이나 ‘’가 객체로 평가될 때도 있음
📍 null 병합 연산자 (??)
- 좌항의 피연산자가 null 또는 undefined인 경우 우항의 피연산자를 반환하고, 그렇지 않으면 좌항의 피연산자를 반환
- 변수에 기본값을 설정할 때 유용
var foo = null ?? 'default string';
console.log(foo); // => "default string"
'FrontEnd > Javascript' 카테고리의 다른 글
[모던 자바스크립트 Deep Dive🦎] 11장 : 원시 값과 객체의 비교 (0) | 2023.04.26 |
---|---|
[모던 자바스크립트 Deep Dive🦎] 10장 : 객체 리터럴 (0) | 2023.04.06 |
[모던 자바스크립트 Deep Dive🦎] 8장 : 제어문 (0) | 2023.03.29 |
[모던 자바스크립트 Deep Dive🦎] 7장 : 연산자 (0) | 2023.03.29 |
[모던 자바스크립트 Deep Dive🦎] 6장 : 데이터 타입 (0) | 2023.03.24 |
Comments