> 웹 프론트엔드 > JS 튜토리얼 > 비동기적으로 로드된 스크립트가 있는 문서에 쓰기를 실행할 수 없는 이유는 무엇입니까?

비동기적으로 로드된 스크립트가 있는 문서에 쓰기를 실행할 수 없는 이유는 무엇입니까?

Susan Sarandon
풀어 주다: 2024-10-20 14:10:02
원래의
269명이 탐색했습니다.

Why Can't You Execute Write on Documents with Asynchronously-Loaded Scripts?

문서에서 쓰기 실행: 비동기적으로 로드된 스크립트의 문제는 무엇입니까?

비동기적으로 로드된 스크립트로 작업할 때 다음과 같은 문제가 발생할 수 있습니다. 오류 "문서에서 '쓰기'를 실행하지 못했습니다. 명시적으로 열지 않는 한 비동기적으로 로드된 외부 스크립트에서 문서에 쓸 수 없습니다." 이는 문서가 완전히 구문 분석되고 닫힌 후 비동기 스크립트가 로드되어 document.write()와 같은 함수를 사용하여 DOM을 직접 변경할 수 없기 때문에 발생합니다.

솔루션 이해

이 문제를 해결하려면 document.write()를 명시적인 DOM 조작으로 바꿔야 합니다. 콘텐츠 자동 삽입에 의존하는 대신 DOM 요소를 수동으로 생성하고 적절하게 삽입해야 합니다.

빨간색 문자를 삽입하는 다음 인라인 스크립트를 고려하세요. "Hello" 텍스트를 "컨테이너" div에 추가:

<code class="html"><div id="container">
<script>
document.write('<span style="color:red">Hello</span>');
</script>
</div></code>
로그인 후 복사

비동기적으로 로드된 스크립트로 동일한 작업을 수행하려면 인라인 스크립트를 다음 코드로 바꾸세요.

<code class="javascript">var container = document.getElementById("container");
var content = document.createElement("span");
content.style.color = "red";
content.innerHTML = "Hello";
container.appendChild(content);</code>
로그인 후 복사

또는 컨테이너에 다른 콘텐츠가 없으면 간단히 innerHTML을 덮어쓸 수 있습니다.

<code class="javascript">var container = document.getElementById("container");
container.innerHTML = '<span style="color:red;">Hello</span>';</code>
로그인 후 복사

명시적인 DOM 조작을 채택하면 비동기식으로 로드된 스크립트가 문서와 효과적으로 상호 작용하도록 보장할 수 있습니다. 지연된 스크립트 실행으로 인한 제한 사항.

위 내용은 비동기적으로 로드된 스크립트가 있는 문서에 쓰기를 실행할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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