>웹 프론트엔드 >JS 튜토리얼 >Internet Explorer 및 Microsoft Edge에서 forEach 기능이 작동하지 않는 이유는 무엇입니까?

Internet Explorer 및 Microsoft Edge에서 forEach 기능이 작동하지 않는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-20 06:47:02849검색

Why is forEach Function Not Working in Internet Explorer and Microsoft Edge?

최근 Microsoft 브라우저에서 각 기능이 작동하지 않음

웹 애플리케이션에서 제품 선택에 대한 스크립트를 생성하려는 개발자가 Internet Explorer 11 및 Microsoft Edge에서 오류가 발생했습니다. IE9 및 최신 버전에서 해당 기능을 사용할 수 있다고 알려졌음에도 불구하고 forEach 기능이 지원되지 않는다는 오류 메시지가 표시되었습니다.

문제 탐색

forEach 메서드는 일반적으로 배열 요소를 반복하고 각 요소에 함수를 적용하는 데 사용됩니다. 이 경우 개발자는 제품 구성에서 색상 옵션을 선택하는 방법을 활용했습니다. 그러나 조사 결과 다음 코드 조각이 발견되었습니다.

var color_btns = document.querySelectorAll('#color > p');
color_btns.forEach(function(color) {
    color.onclick = function () {
        color_btns.forEach(function(element) {
            if (element.classList.contains('selected')) {
                element.classList.remove('selected');
            }
        });
        color.classList.add('selected');
        document.querySelector('#f_color').value = color.dataset.id;
    };
});

Internet Explorer 및 Microsoft Edge에서 예상대로 작동하지 않아 forEach 함수가 NodeList의 속성이 아니라는 오류가 발생했습니다. querySelectorAll에서 반환되었습니다.

문제 원인

추가 조사 결과 querySelectorAll 및 유사한 메서드에서 반환되는 개체 유형인 NodeList 및 HTMLCollection이 다음과 같은 것으로 확인되었습니다. 실제 배열이 아니라 반복 가능합니다. JavaScript에서 반복 가능 항목은 for-of 루프, 확산 연산자 또는 구조 분해 할당을 사용하여 반복할 수 있는 객체입니다.

NodeList 객체는 최근 forEach 메소드에 대한 지원을 얻었지만 HTMLCollection 객체는 지원하지 않으며 앞으로도 그럴 것으로 예상되지 않습니다. 그것을 지원하기 위해. 이는 HTMLCollection에 forEach 메소드를 추가하면 잠재적으로 기존 코드가 손상될 수 있기 때문에 이전 버전과의 호환성 문제 때문입니다.

Polyfilling forEach

이 문제를 해결하려면 다음을 수행하는 것이 좋습니다. NodeList 객체에 대한 forEach 메소드를 폴리필합니다. 폴리필에는 기본적으로 지원되지 않는 개체에 메서드를 추가하는 작업이 포함됩니다. 다음 코드 조각은 NodeList에 대해 forEach를 폴리필할 수 있습니다.

if (typeof NodeList !== "undefined" && NodeList.prototype && !NodeList.prototype.forEach) {
    NodeList.prototype.forEach = Array.prototype.forEach;
}

위 코드에 표시된 대로 직접 할당은 열거 가능, 구성 가능 및 쓰기 가능이 모두 true여야 하고 값 속성이기 때문에 가능합니다.

폴리필 반복성

또한 NodeList 객체를 반복 가능하게 만들어 for-of 루프 및 스프레드 연산자를 사용하여 반복을 지원할 수도 있습니다. 이는 다음 폴리필을 사용하여 달성할 수 있습니다.

if (typeof Symbol !== "undefined" && Symbol.iterator && typeof NodeList !== "undefined" && NodeList.prototype && !NodeList.prototype[Symbol.iterator]) {
    Object.defineProperty(NodeList.prototype, Symbol.iterator, {
        value: Array.prototype[Symbol.iterator],
        writable: true,
        configurable: true
    });
}

폴리필 사용 예

이러한 폴리필을 통합하면 원본 코드를 수정하여 지원되는 모든 환경에서 원활하게 실행될 수 있습니다. 브라우저:

// Polyfilling forEach for NodeList
if (typeof NodeList !== "undefined" && NodeList.prototype && !NodeList.prototype.forEach) {
    NodeList.prototype.forEach = Array.prototype.forEach;
}

// Polyfilling iterability for NodeList
if (typeof Symbol !== "undefined" && Symbol.iterator && typeof NodeList !== "undefined" && NodeList.prototype && !NodeList.prototype[Symbol.iterator]) {
    Object.defineProperty(NodeList.prototype, Symbol.iterator, {
        value: Array.prototype[Symbol.iterator],
        writable: true,
        configurable: true
    });
}

var color_btns = document.querySelectorAll('#color > p');
color_btns.forEach(function(color) {
    color.onclick = function () {
        color_btns.forEach(function(element) {
            if (element.classList.contains('selected')) {
                element.classList.remove('selected');
            }
        });
        color.classList.add('selected');
        document.querySelector('#f_color').value = color.dataset.id;
    };
});

이 업데이트된 코드 조각은 Internet Explorer 및 Microsoft Edge를 포함한 모든 브라우저에서 의도한 대로 작동해야 합니다.

위 내용은 Internet Explorer 및 Microsoft Edge에서 forEach 기능이 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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