CSS值的來源
首先,我們知道CSS雖然語法簡單,但也不是瞎寫的,其屬性和值都是官方定義好了的,確切的說是瀏覽器廠商定義好的。
這些給定的值無外乎來源以下情況:
inherit 表示從祖先元素繼承得到值。每個屬性都有。
initial 表示用戶代理的預設值。每個屬性都有。
瀏覽器專有的值,通常有-ms-,-webkit-等前綴,也有一些值並無前綴。
瀏覽器共有的值,雖然共有,但各瀏覽器在實作上不一定相同。
因此可以肯定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渲染流程
Geoko渲染流程
actual value
則是最後瀏覽器可用的值,比如說所有瀏覽器都不能處理小數點後7位,因此會縮小精度。
這4個值源自於規範,其他瀏覽器實作可能並不依此4步驟流程運作,但目前主流瀏覽器都是依此流程
注意 層疊不同於繼承。層疊是對單一css屬性而言,繼承則是對元素而言。層疊常伴隨著權重問題。
Chrome開發者
指定值(3種)
用戶代理預設值(不可更改)
- 用戶代理預設值(不可更改)
重大的給覆蓋了樣式。
點選4可以跳到對應的 節點和樣式視圖。 4之下的部分錶示從哪個元素繼承了樣式,通常從這裡就可以看到元素的祖先DOM鏈.·
灰色部分
,表示規則不可用且在運行時計算。
例子:
有盒子代表形成了文檔即對應前面的used value)
最後實際值在這(直接在頁面上看):
可以看到如果有padding,padding會在形成文檔之後在形成文檔之後在形成文檔之後在顯示到瀏覽器上時加到視覺上的寬高里去。當然如果有box-sizing屬性的指定則又不一樣,但可以得知這是發生在最後一步的。
CSS值的來源
首先,我們知道CSS雖然語法簡單,但也不是瞎寫的,其屬性和值都是官方定義好了的,確切的說是瀏覽器廠商定義好的。
這些給定的值無外乎來源以下情況:
inherit 表示從祖先元素繼承得到值。每個屬性都有。
initial 表示用戶代理的預設值。每個屬性都有。
瀏覽器專有的值,通常有-ms-,-webkit-等前綴,也有一些值並無前綴。
瀏覽器共有的值,雖然共有,但各瀏覽器在實作上不一定相同。
因此可以肯定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渲染流程
Geoko渲染流程
actual value
則是最後瀏覽器可用的值,比如說所有瀏覽器都不能處理小數點後7位,因此會縮小精度。
這4個值源自於規範,其他瀏覽器實作可能並不依此4步驟流程運作,但目前主流瀏覽器都是依此流程
注意 層疊不同於繼承。層疊是對單一css屬性而言,繼承則是對元素而言。層疊常伴隨著權重問題。
Chrome開發者
指定值(3種)
用戶代理預設值(不可更改)
- 用戶代理預設值(不可更改)
重大的給覆蓋了樣式。
點選4可以跳到對應的 節點和樣式視圖。 4之下的部分錶示從哪個元素繼承了樣式,通常從這裡就可以看到元素的祖先DOM鏈.·
灰色部分
,表示規則不可用且在運行時計算。
例子:
有盒子代表形成了文檔即對應前面的used value)
最後實際值在這(直接在頁面上看):
可以看到如果有padding,padding會在形成文檔之後在形成文檔之後在形成文檔之後在顯示到瀏覽器上時加到視覺上的寬高里去。當然如果有box-sizing屬性的指定則又不一樣,但可以得知這是發生在最後一步的。
更多css值 相關文章請關注PHP中文網!

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

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

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

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

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

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

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

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


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

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

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