JavaScript 비교에는 어떤 항등 연산자(== 대 ===)를 사용해야 합니까?
P粉023650014
2023-08-23 12:29:52
<p>JSLint를 사용하여 JavaScript를 탐색하고 있는데 <code>==</code> (두 개의 등호)를 <code>===</code> 등호) <code>if</code> 내에서 <code>idSele_UNVEHtype.value.length == 0</code> </p>
<p><code>==</code>를 <code>===</code>로 바꾸면 성능상 이점이 있나요? </p>
<p>비교 연산자가 많기 때문에 성능이 향상되면 좋겠습니다. </p>
<p>유형 변환 없이 <code>==</code>에 비해 성능이 향상됩니까? </p>
==
연산자 사용(Equal)===
연산자(Identity) 사용이것은 항등 연산자
==
가 유형 캐스트를 수행하기 때문입니다. 이는 해석기가 비교하기 전에 암시적으로 값 변환을 시도한다는 것을 의미합니다.반면에 식별 연산자
===
는 형 강제를 하지 않기 때문에 비교할 때 값이 변환되지 않습니다.엄격 항등 연산자(
===
) 的行为与抽象相等运算符 (==
)는 유형 변환이 수행되지 않는다는 점을 제외하면 동일하며, 동일한 것으로 간주되려면 유형이 동일해야 합니다.참조: JavaScript 튜토리얼: 비교 연산자
==
运算符将在进行任何必要的类型转换后比较是否相等。===
运算符不会进行转换,因此如果两个值不是同一类型,===
将简单地返回假
. 둘 다 똑같이 빠릅니다.Douglas Crockford의 위대한 JavaScript: The Good Parts一个>,
의 인용문업데이트
@Casebash의 댓글과 @Phillipe Laybaert의 객체에 대한 답변. 객체의 경우
으아아아==
和===
서로 일관되게 동작합니다(특별한 경우 제외).특별한 경우는
으아아아toString
或valueOf
方法。例如,考虑将字符串基元与使用String
생성자에 의해 생성된 문자열 개체로 인해 동일한 기본 요소로 평가되는 개체와 기본 요소를 비교할 때입니다.여기
==
运算符检查两个对象的值并返回true
,但是===
看到它们类型不同并返回false
。哪一个是正确的?这实际上取决于您要比较的内容。我的建议是完全绕过这个问题,只是不要使用String
생성자는 문자열 리터럴에서 문자열 객체를 생성합니다.참고
https://262.ecma-international.org/5.1/#sec-11.9 .3