搜尋

css 值

Feb 15, 2017 pm 01:12 PM

CSS值的來源

首先,我們知道CSS雖然語法簡單,但也不是瞎寫的,其屬性和值都是官方定義好了的,確切的說是瀏覽器廠商定義好的。

這些給定的值無外乎來源以下情況:

  1. inherit 表示從祖先元素繼承得到值。每個屬性都有。

  2. initial 表示用戶代理的預設值。每個屬性都有。

  3. 瀏覽器專有的值,通常有-ms-,-webkit-等前綴,也有一些值並無前綴。

  4. 瀏覽器共有的值,雖然共有,但各瀏覽器在實作上不一定相同。

因此可以肯定css相容問題多來自瀏覽器廠商實作css渲染的不一致和進化程度不一造成。

CSS規範中的值

最終呈現給用戶的值經過了4步: 首先指定的值(the "specified value"), 然後是通過了繼承的值(the "computed value"), 然後轉換為使用值(the "used value"), 最後是因為瀏覽器本身限制原因而得到的實際值(the "actual value").

指定值-->計算值-->使用值-->實際值

Specified value

指定值有3種可能,一是用戶代理的預設值即initial,一是美工寫在程式裡的值,一是顯示指定繼承的值即inherit.

通常, inherit和initial都不必顯示指定。但在某些情況下這2個值非常有用。

computed value

這是在還沒形成文檔前,渲染引擎解析css文件,透過層疊規則繼承關係計算出來的值。

used value

這是css結合html形成文件後所得到的值。

理解計算值和使用值的差別就在於 瀏覽器是先分別解析HTML和CSS文件,然後再把它們融合起來。具體可參考這2張圖。

webkit渲染流程
css值

Geoko渲染流程
css值

actual value

則是最後瀏覽器可用的值,比如說所有瀏覽器都不能處理小數點後7位,因此會縮小精度。

這4個值源自於規範,其他瀏覽器實作可能並不依此4步驟流程運作,但目前主流瀏覽器都是依此流程

注意 層疊不同於繼承。層疊是對單一css屬性而言,繼承則是對元素而言。層疊常伴隨著權重問題。

Chrome開發者

css值

  1. 指定值(3種)

  2. 用戶代理預設值(不可更改)

  3. 用戶代理預設值(不可更改)
  4. 重大的給覆蓋了樣式。

  5. 點選4可以跳到對應的 節點和樣式視圖。 4之下的部分錶示從哪個元素繼承了樣式,通常從這裡就可以看到元素的祖先DOM鏈.·

  6. 灰色部分
可以更改

,表示規則不可用且在運行時計算。

例子:css值

我現在指定h1的高度如下

css值

查看computed value可以看到chrome保留小數點後4位:

有盒子代表形成了文檔即對應前面的used value)

css值

最後實際值在這(直接在頁面上看):

css值

可以看到如果有padding,padding會在形成文檔之後在形成文檔之後在形成文檔之後在顯示到瀏覽器上時加到視覺上的寬高里去。當然如果有box-sizing屬性的指定則又不一樣,但可以得知這是發生在最後一步的。

CSS值的來源

首先,我們知道CSS雖然語法簡單,但也不是瞎寫的,其屬性和值都是官方定義好了的,確切的說是瀏覽器廠商定義好的。

這些給定的值無外乎來源以下情況:

  1. inherit 表示從祖先元素繼承得到值。每個屬性都有。

  2. initial 表示用戶代理的預設值。每個屬性都有。

  3. 瀏覽器專有的值,通常有-ms-,-webkit-等前綴,也有一些值並無前綴。

  4. 瀏覽器共有的值,雖然共有,但各瀏覽器在實作上不一定相同。

因此可以肯定css相容問題多來自瀏覽器廠商實作css渲染的不一致和進化程度不一造成。

CSS規範中的值

最終呈現給用戶的值經過了4步: 首先指定的值(the "specified value"), 然後是通過了繼承的值(the "computed value"), 然後轉換為使用值(the "used value"), 最後是因為瀏覽器本身限制原因而得到的實際值(the "actual value").

指定值-->計算值-->使用值-->實際值

Specified value

指定值有3種可能,一是用戶代理的預設值即initial,一是美工寫在程式裡的值,一是顯示指定繼承的值即inherit.

通常, inherit和initial都不必顯示指定。但在某些情況下這2個值非常有用。

computed value

這是在還沒形成文檔前,渲染引擎解析css文件,透過層疊規則繼承關係計算出來的值。

used value

這是css結合html形成文件後所得到的值。

理解計算值和使用值的差別就在於 瀏覽器是先分別解析HTML和CSS文件,然後再把它們融合起來。具體可參考這2張圖。

webkit渲染流程
css值

Geoko渲染流程
css值

actual value

則是最後瀏覽器可用的值,比如說所有瀏覽器都不能處理小數點後7位,因此會縮小精度。

這4個值源自於規範,其他瀏覽器實作可能並不依此4步驟流程運作,但目前主流瀏覽器都是依此流程

注意 層疊不同於繼承。層疊是對單一css屬性而言,繼承則是對元素而言。層疊常伴隨著權重問題。

Chrome開發者

css值

  1. 指定值(3種)

  2. 用戶代理預設值(不可更改)

  3. 用戶代理預設值(不可更改)
  4. 重大的給覆蓋了樣式。

  5. 點選4可以跳到對應的 節點和樣式視圖。 4之下的部分錶示從哪個元素繼承了樣式,通常從這裡就可以看到元素的祖先DOM鏈.·

  6. 灰色部分
可以更改

,表示規則不可用且在運行時計算。

例子:css值

我現在指定h1的高度如下

css值

查看computed value可以看到chrome保留小數點後4位:

有盒子代表形成了文檔即對應前面的used value)

css值

最後實際值在這(直接在頁面上看):

css值

可以看到如果有padding,padding會在形成文檔之後在形成文檔之後在形成文檔之後在顯示到瀏覽器上時加到視覺上的寬高里去。當然如果有box-sizing屬性的指定則又不一樣,但可以得知這是發生在最後一步的。

更多css值 相關文章請關注PHP中文網!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
CSS Flexbox與網格:全面評論CSS Flexbox與網格:全面評論May 12, 2025 am 12:01 AM

選擇Flexbox還是Grid取決於佈局需求:1)Flexbox適用於一維佈局,如導航欄;2)Grid適合二維佈局,如雜誌式佈局。兩者在項目中可結合使用,提升佈局效果。

如何包括CSS文件:方法和最佳實踐如何包括CSS文件:方法和最佳實踐May 11, 2025 am 12:02 AM

包含CSS文件的最佳方法是使用標籤在HTML的部分引入外部CSS文件。 1.使用標籤引入外部CSS文件,如。 2.對於小型調整,可以使用內聯CSS,但應謹慎使用。 3.大型項目可使用CSS預處理器如Sass或Less,通過@import導入其他CSS文件。 4.為了性能,應合併CSS文件並使用CDN,同時使用工具如CSSNano進行壓縮。

Flexbox vs Grid:我應該學習兩者嗎?Flexbox vs Grid:我應該學習兩者嗎?May 10, 2025 am 12:01 AM

是的,youshouldlearnbothflexboxandgrid.1)flexboxisidealforone-demensional,flexiblelayoutslikenavigationmenus.2)gridexcelstcelsintwo-dimensional,confffferDesignssignssuchasmagagazineLayouts.3)blosebothenHancesSunHanceSlineHancesLayOutflexibilitibilitibilitibilitibilityAnderibilitibilityAndresponScormentilial anderingStruction

軌道力學(或我如何優化CSS KeyFrames動畫)軌道力學(或我如何優化CSS KeyFrames動畫)May 09, 2025 am 09:57 AM

重構自己的代碼看起來是什麼樣的?約翰·瑞亞(John Rhea)挑選了他寫的一個舊的CSS動畫,並介紹了優化它的思維過程。

CSS動畫:很難創建它們嗎?CSS動畫:很難創建它們嗎?May 09, 2025 am 12:03 AM

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For

@KeyFrames CSS:最常用的技巧@KeyFrames CSS:最常用的技巧May 08, 2025 am 12:13 AM

@keyframesispopularduetoitsversatoryand and powerincreatingsmoothcsssanimations.keytricksinclude:1)definingsmoothtransitionsbetnestates,2)使用AnimatingMultatingMultationMultationProperPertiessimultane,3)使用使用4)使用BombingeNtibalibility,4)使用CombanningWiThjavoFofofofoftofofo

CSS計數器:自動編號的綜合指南CSS計數器:自動編號的綜合指南May 07, 2025 pm 03:45 PM

CSSCOUNTERSAREDOMANAGEAUTOMANAMBERINGINWEBDESIGNS.1)他們可以使用forterablesofcontents,ListItems,and customnumbering.2)AdvancedsincludenestednumberingSystems.3)挑戰挑戰InclassINCludeBrowsEccerCerceribaliblesibility andperformiballibility andperformissises.4)創造性

使用捲軸驅動動畫的現代滾動陰影使用捲軸驅動動畫的現代滾動陰影May 07, 2025 am 10:34 AM

使用滾動陰影,尤其是對於移動設備,是克里斯以前涵蓋的一個微妙的UX。傑夫(Geoff)涵蓋了一種使用動畫限制屬性的新方法。這是另一種方式。

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最新版

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

MantisBT

MantisBT

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