Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 실행 컨택스트
- 번들러
- fetch 취소
- 로드마크
- 비동기 작업
- webpack
- 화살표 함수
- debounce
- 호출 스택
- 클론코딩
- 마이크로태스크
- AbortController
- localtunnel
- 자바스크립트
- pushstate
- 함수형
- 로컬터널
- 이터러블
- hoisting
- Call stack
- Lexical environment
- 웹팩
- 넘블
- relatedTarget
- 매클로태스크
- JavaScript
- 렉시컬 환경
- 이벤트 루프
- 호이스팅
- 유사배열
Archives
- Today
- Total
내가 보려고 만든 개발 공부 일지
Typescript - 매번 null , undefined 체크의 귀찮음 본문
const el:HTMLDivElement | null = document.querySelector('div.toast');
위와 같은 코드가 있다고 할때, 여기서 그냥
el.firstChild
이렇게 쓰면 el 값이 null 일 수 도 있다고 에러를 준다…
그래서 if(el) ~~ 이런식으로 falsy 값 체크를 해주야 되는데
매번 코드를 짤때마다 이 짓을 하기엔 너무 번거롭다.
로직 흐름상 절대로 null 이나 undefined 같은 값이 절대 오지 않는 경우에는
el!.firstChild --> 이처럼 변수 뒤쪽에 느낌표 (assertion operator) 를 써주면 되고
이건 컴파일러에게 "이값은 절대 null , undefined 이 될 수 없으니 그냥 넘어가" 라는 뜻이다.
+ 추가적으로 null / undefined 체크 연산자로 물음표 ? 도 있다.
let x = someObj?.someVal.check();
이런 코드가 있을때, "someObj 가 null 또는 undefined 면 실행을 멈추고 undefined 를 린턴해라" 라는 뜻이다.
요약 :
어떤 변수의 내부 값에 접근할때 TS 컴파일러는 항상 null, undefined 체크를 하는데
매번 if 로 체크하는것은 번거로우니 ! , ? 연산자를 사용한다.
! : non-null assertion -> null, undefined 일 경우는 없으니 계속 진행해라.
? : optional chaining -> null, undefined 이면 undefined 을 리턴해라.
'Typescript' 카테고리의 다른 글
Typescript 타입추론 & 타입단언 (0) | 2021.07.02 |
---|---|
Interface vs Type (0) | 2021.07.02 |
Comments