>  기사  >  웹 프론트엔드  >  jQuery를 사용하여 스크립트 요소를 추가할 때 'onload' 이벤트가 실행되지 않는 이유는 무엇입니까?

jQuery를 사용하여 스크립트 요소를 추가할 때 'onload' 이벤트가 실행되지 않는 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-04 02:45:02314검색

Why Doesn't the `onload` Event Fire When Appending a Script Element Using jQuery?

스크립트 태그 관련 OnLoad 이벤트 문제

스크립트를 순차적으로 로드하려고 할 때 onload 이벤트가 트리거되지 않는 문제가 발생합니다. . 다음 코드 조각은 문제를 보여줍니다.

function loadScripts(scripts){
    var script = scripts.shift();
    var el = document.createElement('script');
    el.src = script;
    el.onload = function(script){
        console.log(script + ' loaded!');
        if (scripts.length) {
            loadScripts(scripts);
        }
        else {
            console.log('run app');
            MK.init();
        }
    };
    $body.append(el);
}

jQuery($body.append(el))를 사용하여 스크립트 요소가 DOM에 추가되면 onload 이벤트가 실행되지 않습니다. 그러나 기본 JavaScript document.body.appendChild(el)을 사용하면 의도한 대로 이벤트가 트리거됩니다.

해결 방법:

이 문제를 해결하려면 다음과 같이 코드를 수정하세요.

function loadScripts(scripts){
    var script = scripts.shift();
    var el = document.createElement('script');
    $body.append(el);
    el.onload = function(script){
        console.log(script + ' loaded!');
        if (scripts.length) {
            loadScripts(scripts);
        }
        else {
            console.log('run app');
            MK.init();
        }
    };
    el.src = script;
}

src 속성을 설정하기 전에 DOM에 스크립트를 첨부하면 onload 이벤트가 예상대로 실행됩니다. 또한 브라우저 간 호환성을 위해 jQuery의 getScript() 메소드 사용을 고려해보세요.

위 내용은 jQuery를 사용하여 스크립트 요소를 추가할 때 'onload' 이벤트가 실행되지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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