일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- Android
- ListView
- go
- var
- 싱글 스레드
- Python
- 연산자
- Overloading
- HP
- 오버로딩
- Array
- 리스트 뷰
- js
- Kotlin
- 노트북 추천
- javascript
- 배열
- 패널 교체
- golang
- 안드로이드
- 자바
- 함수
- 파이썬
- adapter
- node.js
- 자바스크립트
- 코틀린
- 노트북
- Java
- as?
Archives
- Today
- Total
Bbaktaeho
[Javascript] null 병합 연산자 '??' 와 OR 연산자 '||' 의 차이 (자바스크립트, nullish coalescing, falsy값) 본문
프로그래밍 (Programming)/자바스크립트 (JavaScript)
[Javascript] null 병합 연산자 '??' 와 OR 연산자 '||' 의 차이 (자바스크립트, nullish coalescing, falsy값)
Bbaktaeho 2020. 8. 24. 23:41반응형
📚 유효성 확인
- 사용할 변수가 유효한지 확인해야 함
- null 또는 undefined 를 참조하게 되면 에러를 발생시킬 것임
- 코틀린 언어같은 경우 엘비스 연산자(?:) 처럼 확인 후에 다음 동작을 수행하는 연산자가 존재함
- 자바스크립트도 여러가지 방법이 있지만 ??, || 를 확인하고 둘의 차이를 비교할 것임
📗 OR 연산자
피연산자 둘 중 하나 이상이 참이면 참을 반환
-
true가 되는 값 || false가 되는 값 ⇒ true가 되는 값
-
true가 되는 값 || true가 되는 값 ⇒ true가 되는 값
-
false가 되는 값 || false가 되는 값 ⇒ false가 되는 값
-
조건문에서 활용
const first = true; const second = false; if(first || second) console.log("OR :", true); if(first && second) console.log("AND :",true);
OR : true
-
boolean값이 아닌 곳에서 활용 1 (피연산자가 두 개 일 때)
const first = "first"; const second = "second"; const third = null; const result1 = first || second; const result2 = second || third; const result3 = third || first; console.log(result1); console.log(result2); console.log(result3);
first second first
-
boolean값이 아닌 곳에서 활용 2 (피연산자가 여러 개 일 때)
-
첫 번째 truthy 값을 찾는다
-
&& 연산자는 반대로 동작함
const first = "first"; const second = "second"; const third = null; const result1 = first || second || third; const result2 = second || first || second; const result3 = third || second || first; console.log(result1); console.log(result2); console.log(result3);
first second second
-
-
node.js 포트 할당(예시)
환경변수가 존재하지 않다면 9000 포트로 할당됨
const port = process.env.NODE_ENV || 9000;
📒 Null 병합 연산자
여러 피연산자 중 존재하는 변수의 값을 찾음
-
value1 ?? value2 ⇒ value1이 존재하는 변수라면 그 값이 반환, 그렇지 않으면 value2
-
(value1 !== null && value1 !== undefined) ? value1 : value2; 와 동등한 코드(삼항연산자)
-
null 병합 연산자 사용 1 (피연산자가 두 개 일 때)
let a = "a는 널이 아닌 값" let test1 = a ?? '대체 값' let test2 = (a !== null && a !== undefined) ? a : '대체 값'; console.log(test1); console.log(test2); a = null; test1 = a ?? '대체 값'; test2 = (a !== null && a !== undefined) ? a : '대체 값'; console.log(test1); console.log(test2);
a는 널이 아닌 값 a는 널이 아닌 값 대체 값 대체 값
-
null 병합 연산자 사용 2 (피연산자가 여러 개 일 때)
null 이나 undefined가 아닌 첫 번째 피연산자 찾기
let first = null; let second = "이"; let third = "삼"; let fourth = null console.log(first ?? second ?? third ?? fourth ?? "Anonymous");
이
📘 ??, || 비교
첫 번째 존재하는 변수의 값을 반환하는 연산자
-
|| 는 첫 번째 truthy 값을 반환
-
?? 는 첫 번째 정의된 값을 반환
-
두 연산자의 차이점
let value = 0 let result = value ?? "정의되지 않은 변수" console.log(result); result = value || "falsy한 변수" console.log(result);
0 falsy한 변수
javascript의 falsy한 값
false null undefined 0 -0 0n NaN ""
반응형
'프로그래밍 (Programming) > 자바스크립트 (JavaScript)' 카테고리의 다른 글
[Javascript] Generator 활용과 장점 (iterable, iterator, lazy evaluation) (0) | 2020.10.21 |
---|---|
[Javascript] Generator, Iterator, Iterable (제너레이터, 이터레이터, function*) (0) | 2020.10.17 |
[Javascript/Node.js] 싱글 스레드 프로그래밍 (uncaughtExcetion) (0) | 2020.05.26 |
[Javascript/Node.js] 비동기 프로그래밍 (자바스크립트, 비동기, 노드, nextTick) (0) | 2020.05.25 |
[Javascript/Array] find, findIndex, indexOf (배열 검색) (0) | 2020.05.24 |