개발/JavaScript

Javascript 동일성 비교 시 ==, === 차이점

haloper 2016. 5. 12. 17:18

Javascript 동일성 비교 시 ==, === 차이점


==는 두 개의 입력값을 같은 type으로 변환하여 같은 값을 가지고 있는지 비교작업을 수행합니다. 이는 의미론적 비교방법이라고 할 수 있습니다. 반면, ===는 type 변환을 하지 않은 상태로 비교작업을 수행하며 type이 틀릴경우 false를 반환합니다.


"1" == 1 // true

"1" === 1 // false

null == undefined // true

null === undefined // false


동일성을 비교하는 방법중에 또다른 방법이 있습니다. 일부 최신 브라우저에서 지원하고 있는 Object.is 라는 함수 입니다. 기본적으로 === 와 같다고 볼 수 있지만, 일부 특수한 값에 대하여 다르게 동작합니다.


NaN(Not a Number)는 연산중에 발생할 수 있는 특수한 값으로 0을 0으로 나누었을 때 발생하는 값 입니다. Javascript에서 NaN에 대한 비교값(==, ===)은 자기 자신(NaN)을 포함한 모든 값과 틀린 것으로 간주합니다. 하지만, Object.is 함수는 NaN과 NaN 비교 시 true 값을 리턴해 줍니다.


NaN === NaN // false

NaN == NaN // false

Object.is(NaN, NaN) // true


기호를 가진 0의 경우에도 Object.is는 다르게 동작합니다. ==, === ㅂ교시 0, -0, +0은 같은 값으로 판단되지만, Obejct.is로 비교시 다른 값으로 판단해 줍니다.


0 == +0 && +0 == -0 // true

0 === +0 && +0 === -0 // true

Object.is(-0, +0) // false


참고로 무한대를 나타내는 Infinity 키워드의 경우 3가지 비교법 모두 true를 나타냅니다.