JavaScript의 평등 이해: "0"과 "False"의 수수께끼
JavaScript에서 평등 연산자(==)는 비교하기 전에 피연산자를 공통 유형으로 변경하면 예기치 않은 결과가 발생할 수 있습니다. ==를 사용하여 "0"을 false로 테스트할 때 한 가지 수수께끼 같은 수수께끼가 발생합니다.
다음 코드를 고려하세요.
"0" == false // true false == "0" // true
이러한 표현식은 true로 평가되어 "0"이 false와 동일함을 의미합니다. . 그러나 이는 "ha"를 인쇄하는 if("0")의 동작과 모순됩니다:
if("0") console.log("ha") // prints "ha"
이 수수께끼를 풀려면 "진실" 값과 "거짓" 값의 개념을 파헤쳐야 합니다. 자바스크립트에서. == 연산자는 "0"을 부울 값으로 강제 변환하는데 이는 거짓입니다. 그러나 if 문은 비어 있지 않은 문자열을 실제 값으로 해석합니다.
이러한 불일치를 피하려면 동등성을 테스트할 때 엄격한 동등 연산자(===)를 사용하는 것이 중요합니다. ===는 유형 강제 없이 값을 직접 비교합니다.
"0" === false // false
아래 표는 JavaScript의 참 값과 거짓 값을 보여줍니다.
Value | Truthy | Falsey |
---|---|---|
0 | Falsey | True |
"0" | Truthy | False |
"" | Falsey | True |
==는 다음과 같은 결과를 초래할 수 있다는 점을 기억하세요. 다양한 유형의 값을 비교할 때 예상치 못한 결과가 발생합니다. 정확하고 명확한 비교를 위해 항상 ===를 선택하세요.
위 내용은 JavaScript에서 '0'이 'False'와 동일한 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!