CSS3中border-radius、box-shadow與gradient那點事兒


一、border-radius

border-radius用於添加圓角邊框,用處非常廣泛。

1)一個值,代表了四個角

.radius-one {
    /* Safari 3-4, iOS 1-3.2, Android 1.6- */
    -webkit-border-radius: 12px; 
            
    /* Firefox 1-3.6 */
    -moz-border-radius: 12px; 
              
    /* Opera 10.5, IE 9, Safari 5, Chrome, Firefox 4, iOS 4, Android 2.1+ */
    border-radius: 12px; 
}

2)三個值,中間的值代表右上和左下

.radius-three {
    /* top left, top right|bottom left, bottom right */
    border-radius: 5px 20px 5px;
}

 

3)斜杠設置第二組值

“/”前是指圓角的水平半徑,而“/”后是指圓角的垂直半徑,他們兩都遵循TRBL(上右下左)的順序原則。左上角是10px/40px,右上角是20px/30px,以此類推。

.radius-five {
    border-radius: 10px 20px 30px 40px/40px 30px 20px 10px; /* horizontal radius / vertical radius */
}

4)背景圖將被裁剪

.radius-img {
    background: url(img.jpg) no-repeat right bottom;
    border-radius: 12px;
}

 

二、box-shadow

box-shadow 向框添加一個或多個陰影。該屬性是由逗號分隔的陰影列表,每個陰影由 2-4 個長度值、可選的顏色值以及可選的 inset 關鍵詞來規定。省略長度的值是 0。

box-shadow: h-shadow v-shadow blur spread color inset;

偏移方向如下圖所示:

1)單層陰影

.box-shadow {
    /* Safari 3-4, iOS 4.0.2 - 4.2, Android 2.3+ */
    -webkit-box-shadow: 3px 3px 5px 6px #ccc;  
              
    /* Firefox 3.5 - 3.6 */
    -moz-box-shadow:    3px 3px 5px 6px #ccc;  
              
    /* Opera 10.5, IE 9, Firefox 4+, Chrome 6+, iOS 5 */
    box-shadow:         3px 3px 5px 6px #ccc;  
}

2)多重陰影

黑色:帶模糊和陰影尺寸

紫色與黃色:只有水平和垂直

紅色與藍色:水平、垂直以及模糊

.box-shadow-more {
    box-shadow: 0 0 10px 5px black, 
                40px -30px purple, 
                40px 30px 50px red, 
                -40px 30px yellow, 
                -40px -30px 50px blue;
}

三、CSS3 Gradient

1)linear-gradient(線性漸變)

在創建漸變的過程中,可以指定多個中間顏色值,這個值稱為色標。每個色標包含一種顏色和一個位置,瀏覽器從每個色標的顏色淡出到下一個,以創建平滑的漸變。

PhotoShop中的漸變編輯器如下所示:

 

CSS兼容性如下

 

各個瀏覽器語法如下:

-moz-linear-gradient( [<point> || <angle>,]? <stop>, <stop> [, <stop>]* )

-webkit-linear-gradient( [<point> || <angle>,]? <stop>, <stop> [, <stop>]* )//最新發布書寫語法
-webkit-gradient(<type>, <point> [, <radius>]?, <point> [, <radius>]? [, <stop>]*) //老式語法書寫規則

-o-linear-gradient([<point> || <angle>,]? <stop>, <stop> [, <stop>]); /* Opera 11.10+ */

filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr=#1471da, endColorstr=#1C85FB);/*IE<9>*/
-ms-filter: "progid:DXImageTransform.Microsoft.gradient (GradientType=0, startColorstr=#1471da, endColorstr=#1C85FB)";/*IE8+*/

linear-gradient([ [ <angle> | to <side-or-corner> ] ,]? <color-stop>[, <color-stop>]+)

 下面是一個實例,與上面的語法一一對應,順序也是一樣的:

.linear-gradient {
  background: -moz-linear-gradient(top,  rgba(255,203,72,1) 0%, rgba(255,156,35,1) 50%);
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(255,203,72,1)), color-stop(50%,rgba(255,156,35,1)));   background: -webkit-linear-gradient(top, rgba(255,203,72,1) 0%,rgba(255,156,35,1) 50%);
  background: -o-linear-gradient(top, rgba(255,203,72,1) 0%,rgba(255,156,35,1) 50%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffcb48', endColorstr='#ff9c23',GradientType=0 );   -ms-filter: "progid:DXImageTransform.Microsoft.gradient (GradientType=0, startColorstr=#ffcb48, endColorstr=#ff9c23)";

  background: linear-gradient(to bottom, rgba(255,203,72,1) 0%,rgba(255,156,35,1) 50%);
}

標准語法對於方向需要使用一個to,而且寫的方向要與其它的相反,如果是top,這里就是bottom

第二個顏色我用了個50%,開始漸變的起始位置

 

還可以設置角度,它是一個由水平線與漸變線產生的的角度,逆時針方向。因此,使用0deg將產生一個左到右橫向梯度,而90度將創建一個從底部到頂部的垂直漸變。

-filter-ms-filter-webkit-gradient就不能用啦。

.linear-gradient-angle {
    background: -moz-linear-gradient(45deg,  rgba(255,203,72,1) 0%, rgba(255,156,35,1) 50%);
    background: -webkit-linear-gradient(45deg,  rgba(255,203,72,1) 0%,rgba(255,156,35,1) 50%);
    background: -o-linear-gradient(45deg,  rgba(255,203,72,1) 0%,rgba(255,156,35,1) 50%);
    background: linear-gradient(45deg,  rgba(255,203,72,1) 0%,rgba(255,156,35,1) 50%);
}

 

2)radial-gradient(徑向漸變)

CSS兼容性與上面的線性漸變類似。

各個瀏覽器語法如下:

-moz-radial-gradient([<bg-position> || <angle>,]? [<shape> || <size>,]? <color-stop>, <color-stop>[, <color-stop>]*);
-webkit-radial-gradient([<bg-position> || <angle>,]? [<shape> || <size>,]? <color-stop>, <color-stop>[, <color-stop>]*);
-o-radial-gradient([<bg-position> || <angle>,]? [<shape> || <size>,]? <color-stop>, <color-stop>[, <color-stop>]*);
radial-gradient([ [ <shape> || <size> ] [ at <position> ]? , | at <position>, ]?<color-stop>[ , <color-stop> ]+)

下面是一個實例,與上面的語法一一對應:

.radial-gradient {
    background: -moz-radial-gradient(10px 20px, #f00, #ff0 40%, #080);
    background: -webkit-radial-gradient(10px 20px, #f00, #ff0 40%, #080);
    background: -o-radial-gradient(10px 20px, #f00, #ff0 40%, #080);
    background: radial-gradient(at 10px 20px, #f00, #ff0 40%, #080);
}

標准語法對於坐標需要使用一個at;

第二個顏色我用了個40%,開始漸變的起始位置

 

demo下載:

http://download.csdn.net/detail/loneleaf1/9146297

 

參考資料:

https://css-tricks.com/almanac/properties/b/border-radius/   css-tricks border-radius

http://www.cnblogs.com/mofish/p/3832136.html   從css3書寫順序引出來的border-radius參數

https://css-tricks.com/almanac/properties/b/box-shadow/    css-tricks border-shadow

http://www.basecss.net/article/box-shadow.html   [譯]Box-shadow, CSS3最好的特性之一

http://www.webhek.com/css-box-shadow-property    CSS陰影效果(Box-shadow)用法趣味講解

http://www.cnblogs.com/lhb25/archive/2013/01/30/css3-linear-gradient.html   CSS3 線性漸變(linear-gradient)

http://www.cnblogs.com/lhb25/archive/2013/02/24/css3-radial-gradient.html   CSS3 徑向漸變(radial-gradient)

http://www.w3cplus.com/css3/new-css3-linear-gradient.html   再說CSS3漸變——線性漸變

http://blog.csdn.net/playboyanta123/article/details/9303857    radial-gradient CSS3的蛋疼的徑向漸變


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM