>웹 프론트엔드 >JS 튜토리얼 >`h.className = h.className 으로 인해 내 JavaScript 코드가 실패하는 이유는 무엇입니까? \' 오류\' : \' 오류\'`?

`h.className = h.className 으로 인해 내 JavaScript 코드가 실패하는 이유는 무엇입니까? \' 오류\' : \' 오류\'`?

DDD
DDD원래의
2024-10-31 21:46:02887검색

Why Does My JavaScript Code Fail with `h.className  = h.className ? ' error' : 'error'`?

연산자 우선순위 수수께끼: JavaScript의 삼항 연산자 및 연결

JavaScript에서 삼항 연산자를 사용하는 것은 특히 다른 연산자와 혼합될 때 혼란스러울 수 있습니다. 연산자. 다음 코드 조각을 고려하십시오.

h.className += h.className ? ' error' : 'error'

이 코드의 목적은 HTML 요소 'h'의 className 속성에 'error' 문자열을 추가하는 것입니다. 그러나 오류로 인해 코드가 실패합니다. 그 이유를 이해하려면 JavaScript의 연산자 우선 순위를 분석해야 합니다.

삼항 연산자(?:)는 할당 연산자(=)보다 우선 순위가 높습니다. 따라서 위의 코드는 다음과 동일합니다.

h.className = h.className + (h.className ? ' error' : 'error')

이 해석이 더 의미가 있습니다. 삼항 연산자는 h.className이 null이 아닌지 또는 정의되지 않은("진실한" 값)지 여부를 확인합니다. true이면 h.className에 'error'를 추가합니다. 그렇지 않으면 '오류'가 추가됩니다.

원래 코드를 수정하려면 괄호 안에 대입 연산자를 명시적으로 추가해야 합니다.

h.className = h.className + (h.className ? ' error' : 'error')

대입 연산자를 괄호 안에 배치하여 재정의합니다. 우선순위 규칙을 적용하고 전체 삼항 표현식이 h.className에 할당되었는지 확인하세요.

위 내용은 `h.className = h.className 으로 인해 내 JavaScript 코드가 실패하는 이유는 무엇입니까? \' 오류\' : \' 오류\'`?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.