> 웹 프론트엔드 > JS 튜토리얼 > JavaScript 함수 이름과 요소 ID의 충돌을 어떻게 피할 수 있습니까?

JavaScript 함수 이름과 요소 ID의 충돌을 어떻게 피할 수 있습니까?

Patricia Arquette
풀어 주다: 2024-12-03 16:23:15
원래의
626명이 탐색했습니다.

How Can JavaScript Function Name Collisions with Element IDs Be Avoided?

JavaScript에서 요소 ID와 함수 이름 충돌

웹 개발자는 JavaScript 함수 이름이 요소 ID와 충돌하는 특이한 문제에 자주 직면합니다. "함수가 아닙니다."와 같은 오류가 발생합니다. 이 문제는 웹 개발 초기에 발생한 JavaScript의 레거시 기능에서 비롯됩니다.

Legacy Scope Chain Issue

JavaScript 1.0~1.3에서는 이러한 문제가 발생하지 않았습니다. 프로그래밍 언어와 DOM API의 명확한 구분. 결과적으로 양식 컨트롤은 컨트롤 이름을 포함하여 양식 개체의 속성에 액세스할 수 있습니다. 즉, 선택 요소의 ID가 "border"인 경우 다음 코드가 작동합니다.

function border(border) { alert(border); }
<select>
로그인 후 복사

그러나 이러한 단순성에는 주의할 점이 있습니다. 양식 컨트롤이 양식 내에 배치되면 양식 개체는 범위 체인에서 세 번째 다음이 됩니다. 결과적으로 다음 코드는 실패합니다.

<form>
  <select>
로그인 후 복사

이 경우 양식 개체의 "테두리" 속성이 전역 "테두리" 함수를 가려서 "함수가 아닙니다" 오류가 발생합니다.

W3C DOM 레벨 2 HTML 호환성

이 문제를 해결하려면, W3C DOM 레벨 2 HTML에는 대괄호 속성 접근자 구문을 통해 이름이나 ID로 요소에 액세스하는 기능이 도입되었습니다. 이는 이제 다음 코드가 위의 문제가 있는 코드와 동일하다는 것을 의미합니다.

document.forms["myForm"].elements["border"](this.value)
로그인 후 복사

권장사항

이 충돌 문제를 피하려면 다음 코드를 사용하지 않는 것이 좋습니다. 사용자 정의 함수와 동일한 양식 컨트롤의 이름 또는 ID입니다. 또한 개발자는 함수와 해당 인수 중 하나에 동일한 식별자를 사용하지 않아야 합니다. 이렇게 하면 함수 내에서 함수 개체에 액세스할 수 없게 됩니다.

위 내용은 JavaScript 함수 이름과 요소 ID의 충돌을 어떻게 피할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿