首頁 >web前端 >js教程 >如何覆寫非同步腳本載入中的 document.write() 限制?

如何覆寫非同步腳本載入中的 document.write() 限制?

Patricia Arquette
Patricia Arquette原創
2024-10-20 14:04:02534瀏覽

How to Override document.write() Limitations in Asynchronous Script Loading?

非同步腳本載入:了解document.write() 限制

非同步執行腳本時,在初始頁面載入後,必須意識到它對文檔操作造成的限制。如同控制台訊息中所述,「除非明確打開,否則不可能從非同步載入的外部腳本寫入文件。」

這意味著在此類外部腳本中使用document.write()即使腳本本身載入成功,載入的腳本也不會有效地寫入文件。原因在於非同步腳本在文件被解析並關閉後運行。

要解決這個問題,有必要用顯式 DOM 操作取代 document.write() 。不要直接寫入文檔,而是創建所需的 DOM 元素,然後使用諸如appendChild()、insertBefore()之類的方法將它們附加到文檔中,或透過設定innerHTML屬性。

例如,不要使用文檔內聯腳本中的.write():

在動態載入的腳本中,將其替換為以下內容:

或者,如果容器中沒有其他內容,您可以直接設定innerHTML屬性:

透過遵循這些準則,您可以有效地從非同步載入的腳本中操作DOM,而不會遇到「無法在'Document'上執行'write'」錯誤。

以上是如何覆寫非同步腳本載入中的 document.write() 限制?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn