圓角因使人感覺舒適的友好風格而變得無處不在。這個無處不在也讓很多前端工程師帶來困擾:實現麻煩、兼容困難、性能不佳。而W3C早在 2002年的CSS3草案 中就加入了一個叫 border-radius 的屬性,通過它可以直接來定義HTML元素的圓角制作。
CSS3的border-radius規范
最新草案 中其主要信息如下:
屬性:
border-top-right-radius
border-bottom-right-radius
border-bottom-right-radius
border-bottom-right-radius
值: ?。它們分別是定義角形狀的四分之一橢圓的兩個半徑。
-
-
第一個值是水平半徑。
-
如果第二個值省略,則它等于第一個值,這時這個角就是一個四分之一圓角。
-
如果任意一個值為0,則這個角是矩形,不會是圓的。
-
值不允許是負值。
-
屬性:border-radius。它是上面四個屬性值的簡寫。
值:{1,4} [ / {1,4} ]?
-
如果斜線前后的值都存在,那么斜線前的值設置水平半徑,且斜線后的值設置垂直半徑。如果沒有斜線,則水平半徑和垂直半徑相等。
-
四個值是按照top-left、top-right、 bottom-right、 bottom-left的順序來設置的。如果bottom-left省略,那么它等于top-right。如果bottom-right省略,那么它等于top-left。如果top-right省略,那么它等于top-left。
-
應用范圍:所有的元素,除了table的樣式屬性border-collapse是collapse時
-
內邊半徑等于外邊半徑減去對應邊的厚度。當這個結果是負值時,內邊半徑是0。所以內外邊曲線的圓心并不一定是一致的。
-
border-radius也會導致該元素的背景也是圓的,即使border是none。如果 background-clip 是padding-box,則背景(background)會被曲線的內邊裁剪。如果是border-box則被外邊裁剪。border和padding定義的區域也一樣會被曲線裁剪。
-
所有的邊框樣式(solid、dotted、inset等)都遵照角的曲線。如果設置了border-image,則曲線以外的部分會被裁剪掉。
-
如果角的兩個相鄰邊有不同的寬度,那么這個角將會從寬的邊平滑過度到窄的邊。其中一條邊甚至可以是0。
-
兩條相鄰邊顏色和樣式轉變的中心點是在一個和兩邊寬度成正比的角上。比如,兩條邊寬度相同,這個點就是一個45°的角上,如果一條邊是另外一條邊的兩倍,那么這個點就在一個30°的角上。界定這個轉變的線就是連接在內外曲線上的兩個點的直線
-
角不允許相互重疊,所以當相鄰兩個角半徑的和大于所在矩形區域的大小時,用戶代理(瀏覽器)比如縮小一個或多個角半徑。運算法則如下:f = min(Li/Si),i ∈ {top, right, bottom, left},Ltop = Lbottom = 所在矩形區域的寬,Lleft = Lright = 所在矩形區域的高。如果f < 1,那么所有角半徑都乘以f。
瀏覽器支持
實際中,目前沒有任何一款瀏覽器支持這個屬性,只有部分瀏覽器利用其私有屬性支持部分實現:
-
Firefox對border-radius的支持 :
-moz-border-radius: {1,4} | inherit
-moz-border-radius-bottomleft : | inherit
-moz-border-radius-bottomright: | inherit
-moz-border-radius-topleft: | inherit
-moz-border-radius-topright : | inherit
-
只對每個角設置一個半徑,只支持實現四分之一圓角,并不支持橢圓形圓角。
-
具體每個角的命名規則也和W3C不一致,這個比較討厭。
-
Firefox3圓角已經相當圓滑了,Firefox2比較糟糕,好在它即將終結了。
-
Safari和Chrome對border-radius的支持 :
-webkit-border-radius: {1,2} | inherit
-webkit-border-bottom-left-radius : {1,2} | inherit
-webkit-border-bottom-right-radius : {1,2} | inherit
-webkit-border-top-left-radius: {1,2} | inherit
-webkit-border-top-right-radius : {1,2} | inherit
-
每個屬性有1個或2個值,當有兩個值時1個表示水平半徑,一個表示垂直半徑writing-mode改變也隨之而變)。所以,Safari和Chrome中的圓角可以是橢圓角。
-
webkit的實現方法和 W3C的CSS3草案2005年版本 非常一致,和當前的草案大不同就是簡寫屬性-webkit-border-radius的屬性值也只有1個或2個值,意義和前面相同。
-
Chrome中圓角鋸齒比較嚴重,基本上和Firefox2是同一水平,或許是它的webkit版本較低造成的。
-
由于webkit出生于kHTML,所以把 上面屬性中的webkit換成khtml即會得到以khtml為核心的瀏覽器支持的屬性了。
-
當相鄰的角半徑之和大于所在矩形區域的大小時,都會直接設置所有的角半徑為0,即圓角失效,而不會像Firefox那樣同比率縮小。
-
Opera尚不支持border-radius,雖然 Opera10 alpha擁有眾多的CSS3改進 ,但是依舊看不到對其支持的希望。
-
IE就不用說了,標準的不支持了。從MSDN的 CSS Compatibility and Internet Explorer 中可以看出IE8已經鐵定不支持了。
實際應用
最簡單的應用就是支持的用圓角,不支持的用方角。比如wordpress2.7的后臺、 雅虎口碑UED 的blog和 今天你帶傘了嗎? 。基礎代碼如下:
border-width: 1px;
border-style: solid;
-moz-border-radius: 11px;
-kHTML-border-radius: 11px;
-webkit-border-radius: 11px;
border-radius: 11px;
利用VML可以實現從IE5-7的圓角 ,但是貌似IE8不支持VML了。 組件DD_roundies 就是綜合以上解決方案的一個具體應用。說實話這樣實現出來的圓角也比較粗糙了,我感覺還不如不要。
像VML一樣,Canvas也能實現圓角,切除了IE外,所有的主流瀏覽器都支持。所以就有了兩者結合實現的組件 Cornerz 。
如果上面的現實太痛苦,而又非要用圓角的話,要么一個像素一個像素去拼裝,比如Chunky Borders;要么就老老實實用圖片來實現吧,比如 CSS Mojo 的方式。
分享標題:CSS3的border-radius屬性規范與圓角制作
當前地址:http://vcdvsql.cn/news37/324637.html
成都網站建設公司_創新互聯,為您提供微信小程序、網頁設計公司、網站維護、軟件開發、ChatGPT、電子商務
廣告
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源:
創新互聯