首頁 >web前端 >js教程 >為什麼 JavaScript 中的全域元素 ID 存取在瀏覽器之間有所不同,標準是什麼?

為什麼 JavaScript 中的全域元素 ID 存取在瀏覽器之間有所不同,標準是什麼?

Linda Hamilton
Linda Hamilton原創
2024-12-13 02:06:08650瀏覽

Why Does Global Element ID Access in JavaScript Differ Between Browsers, and What's the Standard?

全域元素ID 存取:符合Web 標準與瀏覽器行為

問題:

在Javascript 中,透過以下方式存取元素它們使用點符號(a.method()) 的ID 在Chrome 中全局有效,但在Firefox中無效。根據網路規範,正確的行為是什麼?此外,Chrome 如何處理 ID 翻譯中的 ID 歧義和特殊字元?

答案:

全域存取元素ID 的行為因所參考的規範而異.

  • HTML4 規範: 不描述此行為明確地。
  • WHATWG HTML 規格: 需要此行為。

瀏覽器歷來採用此行為以實現相容性,Internet Explorer 最初引入了它。 Firefox 也以怪異模式支援它。

正確行為:

根據 WHATWG HTML 規範,具有 ID 的元素應該可以全域存取。然而,依賴全域命名空間進行元素引用通常被認為是不好的做法。

Chrome 中的歧義處理:

Chrome 目前不處理全域變數和元素 ID 很好。如果存在與全域變數具有相同 ID 的元素,則透過全域變數存取該元素可能會導致意外行為。

有特殊字元的 ID 翻譯:

可以使用 getElementById() 方法存取 ID 中的特殊字元。然而,這些字元到全域變數表示的轉換在任何規範中都沒有明確定義。

以上是為什麼 JavaScript 中的全域元素 ID 存取在瀏覽器之間有所不同,標準是什麼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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