>웹 프론트엔드 >CSS 튜토리얼 >`className` 변경이 HTMLCollection의 다른 모든 요소에만 영향을 미치는 이유는 무엇입니까?

`className` 변경이 HTMLCollection의 다른 모든 요소에만 영향을 미치는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-28 03:09:10769검색

Why Does Changing `className` Only Affect Every Other Element in an HTMLCollection?

className은 다른 모든 클래스만 변경

이 코드 조각에서는 className 속성이 다른 모든 요소에 대해서만 변경되는 문제가 발생합니다. 컬렉션에서. 목표는 이 동작의 원인을 이해하고 해결책을 찾는 것입니다.

제공된 코드는 getElementsByClassName() 메서드를 활용하여 "block-default" 클래스가 있는 HTML 요소를 검색합니다. 그런 다음 컬렉션에 있는 각 요소의 className 속성을 "블록 선택"으로 수정합니다. 그러나 결과적으로 대체 요소만 업데이트되고 다른 요소는 원래의 "block-default" 클래스가 남게 됩니다.

원인은 HTMLCollections의 특성에 있습니다. 이러한 컬렉션은 실시간이며 DOM의 현재 상태를 반영합니다. 요소의 className 속성이 수정되면 컬렉션 자체도 영향을 받습니다. 특히, 수정된 요소가 목록에서 제거되므로 컬렉션의 크기가 줄어듭니다.

이 문제를 해결하려면 컬렉션 요소에 대한 이후 변경 사항이 나머지 요소의 인덱스에 영향을 미친다는 점을 기억하는 것이 중요합니다. 해결책은 첫 번째 요소의 className만 일관되게 변경하는 것입니다.

한 가지 방법은 컬렉션을 반복하고 첫 번째 요소를 반복적으로 수정하는 것입니다.

for (var i = 0; i < blockSetLength; i++) {
  blockSet[0].className = "block-selected";
}

이 접근 방식을 사용하면 첫 번째 요소가 일관되게 유지됩니다. 컬렉션 변경 사항에 관계없이 업데이트됩니다.

또는 스프레드 연산자를 사용하면 HTMLCollection을 배열로 변환하여 유연성을 높일 수 있습니다.

var blockArray = [...blockSet];

for (var i = 0; i < blockArray.length; i++) {
  blockArray[0].className = "block-selected";
}

두 경우 모두 첫 번째 요소의 className만 수정하면 컬렉션에 있는 모든 요소의 클래스를 변경하는 원하는 결과를 얻을 수 있습니다.

위 내용은 `className` 변경이 HTMLCollection의 다른 모든 요소에만 영향을 미치는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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