搜尋
首頁web前端css教學為什麼 jQuery 的 `height()` 和 `width()` 對於具有 `display:none` 的元素會傳回非零值?

Why Does jQuery's `height()` and `width()` Return Non-Zero Values for Elements with `display:none`?

jQuery 的非傳統Height() 和Width() 行為與「display:none」

jQuery 的height() 和width( ) 方法是廣泛用於確定網頁上元素的可見尺寸。然而,在處理設定了 CSS 屬性「display:none」的元素時,似乎會出現意外的行為。

問題

傳統上,人們相信具有「display:none」的元素的高度和寬度為零。然而,jQuery 的情況並非總是如此。考慮以下範例:

<code class="html"><div id="target" style="display:none;">
  a
</div></code>
<code class="css">alert($("#target").height());</code>

在此範例中,「目標」元素的高度不為零,而是一個非零值。這種不一致引發了一個問題:為什麼帶有「display:none」的元素有時會在 jQuery 中傳回非零高度和寬度?

答案

要理解這種行為,我們需要深入研究 jQuery 的 height() 和 width() 方法的內部運作原理。當元素的可見 offsetWidth 為 0(表示它是「隱藏」)時,jQuery 會嘗試計算其實際尺寸。它透過暫時覆寫元素的CSS 屬性來實現此目的:

  • position: "absolute"
  • visibility: "hidden"
  • display: "block"

透過這些修改,jQuery 會檢索元素的高度,並根據需要考慮邊框和填充。一旦確定了高度,jQuery 就會恢復原始的 CSS 屬性,確保不會發生可見的變更。

此程序允許 height() 和 width() 對於隱藏元素正確工作,只要它們的父元素可見。本質上,jQuery 模擬了在文件流程之外顯示元素、檢索其尺寸,然後再次隱藏它的行為,所有這些都在幕後透過單一操作完成。這消除了開發人員手動顯示和隱藏元素來獲取其尺寸的需要。

以上是為什麼 jQuery 的 `height()` 和 `width()` 對於具有 `display:none` 的元素會傳回非零值?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
錨定位只是不關心來源訂單錨定位只是不關心來源訂單Apr 29, 2025 am 09:37 AM

錨定定位避開HTML源順序的事實是如此之高,因為它在內容和演示文稿之間的另一個關注點是另一個分離的事實。

保證金是什麼:40px 100px 120px 80px表示?保證金是什麼:40px 100px 120px 80px表示?Apr 28, 2025 pm 05:31 PM

文章討論了CSS保證金屬性,特別是“保證金:40px 100px 120px 80px”,其應用程序以及對網頁佈局的影響。

什麼是不同的CSS邊框特性?什麼是不同的CSS邊框特性?Apr 28, 2025 pm 05:30 PM

本文討論了CSS邊境屬性,重點是自定義,最佳實踐和響應能力。主要論點:邊境 - 拉迪烏斯(Border-Radius)對響應式設計最有效。

什麼是CSS背景,列出屬性?什麼是CSS背景,列出屬性?Apr 28, 2025 pm 05:29 PM

本文討論了CSS背景屬性,它們在增強網站設計方面的用途以及避免的常見錯誤。重點是使用背景大小的響應式設計。

什麼是CSS HSL顏色?什麼是CSS HSL顏色?Apr 28, 2025 pm 05:28 PM

文章討論了CSS HSL顏色,其在網絡設計中的使用以及比RGB的優勢。主要重點是通過直觀的顏色操縱來增強設計和可訪問性。

我們如何在CSS中添加評論?我們如何在CSS中添加評論?Apr 28, 2025 pm 05:27 PM

本文討論了CSS中評論的使用,詳細介紹了單線和多行評論語法。它認為註釋可以增強代碼的可讀性,可維護性和協作,但如果無法正確管理,可能會影響網站性能。

什麼是CSS選擇器?什麼是CSS選擇器?Apr 28, 2025 pm 05:26 PM

本文討論了CSS選擇器,其類型和用於造型HTML元素的用法。它比較ID和類選擇器,並與復雜的選擇器解決性能問題。

哪種類型的CSS持有最高優先級?哪種類型的CSS持有最高優先級?Apr 28, 2025 pm 05:25 PM

本文討論了CSS優先級,重點是具有最高特異性的內聯風格。它解釋了特異性級別,覆蓋方法和用於管理CSS衝突的工具。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具