深入剖析CSS中的線性漸變linear-gradient

在CSS3出現(xiàn)之前,漸變效果只能通過圖形軟件設(shè)計圖片來實現(xiàn),可拓展性差,還影響性能。如今已經(jīng)進(jìn)入CSS3標(biāo)準(zhǔn)的漸變可以很輕松的完成漸變效果。漸變實際上分為線性漸變和徑向漸變兩種,本文介紹線性漸變。
定義
漸變實際上是兩種或多種顏色之間的平滑過渡。而線性漸變是多種顏色沿著一條直線(稱為漸變線)過渡。漸變的實現(xiàn)由兩部分組成:漸變線和色標(biāo)。漸變線用來控制發(fā)生漸變的方向;色標(biāo)包含一個顏色值和一個位置,用來控制漸變的顏色變化。瀏覽器從每個色標(biāo)的顏色淡出到下一個,以創(chuàng)建平滑的漸變,通過確定多個色標(biāo)可以制作多色漸變效果。
[注意]safari4-5、IOS3.2-4.3、android2.1-3只支持線性漸變,且需要添加-webkit-;safari5.1-6、IOS5.1-6.1、android4-4.3支持線性和徑向漸變,且需要添加-webkit-;IE10+及其他高版本瀏覽器支持標(biāo)準(zhǔn)寫法
- <linear-gradient> = linear-gradient([ [ <angle> | to <side-or-corner> ] ,]? <color-stop>[, <color-stop>]+)
- <side-or-corner> = [left | rightright] || [top | bottombottom]
漸變線
漸變線從漸變框中心向兩個方向進(jìn)行拓展,起點(diǎn)和終點(diǎn)是漸變線與經(jīng)過漸變框的一個角的垂直線的相交點(diǎn)

漸變的第一個參數(shù)用于指定漸變線,默認(rèn)是to bottom。有兩種方式指定漸變線方向
【1】使用角度
0deg表示沿著元素的中心線由下向上的方向(類似于y軸),且正角度表示順時針旋轉(zhuǎn)
[注意]對于-webkit-舊版本瀏覽器,如windows系統(tǒng)下的safari瀏覽器來說,0deg表示沿著元素中心線從左向右的方向(類似于x軸),且正角度表示逆時針旋轉(zhuǎn)
所以-webkit-舊版本瀏覽器與標(biāo)準(zhǔn)瀏覽器的之間線性漸變的角度關(guān)系為
-webkit-瀏覽器 = 90deg - 標(biāo)準(zhǔn)瀏覽器
相當(dāng)于
-webkit-linear-gradient(90deg,red,blue) = linear-gradient(0deg,red,blue)
[注意]對于webkit內(nèi)核的瀏覽器來說,使用javascript改變元素的樣式。當(dāng)帶-webkit-的私有樣式和不帶-webkit-的標(biāo)準(zhǔn)樣式同時存在的時候,并不一定是后面覆蓋前面。所以如果兩種寫法產(chǎn)生的效果相同,但參數(shù)不同時,要使用瀏覽器識別來分別寫不同的情況。
【2】使用關(guān)鍵字
- to top -> 0deg
- to rightright -> 90deg
- to bottombottom -> 180deg
- to left -> -90deg(或270deg)
- to top left -> -45deg(或315deg)
- to top rightright -> 45deg
- to bottombottom left -> -135deg(或225deg)
- to bottombottom rightright -> 135deg
[注意]window系統(tǒng)的safari瀏覽器并不支持'to'加方向的關(guān)鍵字,如to left。它只支持方向關(guān)鍵字,如left。當(dāng)然了left 和 to left 方向是正好相反的
色標(biāo)
瀏覽器對于色標(biāo)并沒有默認(rèn)值,且必須設(shè)置至少兩個色標(biāo)。色標(biāo)由顏色和位置組成。顏色使用任何一種顏色模式都可以,而位置可以使用百分比或數(shù)值。
[注意]顏色的位置也可以設(shè)置負(fù)值
【1】必須是顏色在前,位置在后
- //正確
- background-image: linear-gradient(red 0%,blue 100%);
- //錯誤
- background-image: linear-gradient(0% red,100% blue);
【2】位置可以省略,瀏覽器默認(rèn)會把第一個顏色的位置設(shè)置為0%,把最后一個顏色的位置設(shè)置為100%
- background-image: linear-gradient(red 0%,blue 100%);
- //等價于上一個
- background-image: linear-gradient(red,blue);
【3】若漸變只有兩種顏色,且第一個顏色的位置設(shè)置為n%,第二個顏色的位置設(shè)置為m%。則瀏覽器會將0%-n%的范圍設(shè)置為第一個顏色的純色,n%-m%的范圍設(shè)置為第一個顏色到第二個顏色的過渡,m%-100%的范圍設(shè)置為第二個顏色的純色
- background-image: linear-gradient(red 30%,blue 60%);
- //等價于上一個
- background-image: linear-gradient(red 0%,red 30%,blue 60%,blue 100%);
【4】若漸變顏色沒有指定位置,則它們會均勻分布
- background-image: linear-gradient(red,yellow,green,blue);
【5】若多色占據(jù)同一個位置,例a、b、c三色均占據(jù)n%這一位置,則0%-n%為前一種顏色與a顏色的顏色漸變;然后是n%-n%的a顏色與c顏色的顏色突變;n%-100%是c顏色與后一種顏色的顏色漸變。因此,中間的b是無用的
- background-image: linear-gradient(red,yellow 50%,white 50%,black 50%,blue);
- //等價于上一個
- background-image: linear-gradient(red,yellow 50%,black 50%,blue);
重復(fù)漸變
重復(fù)漸變可以實現(xiàn)線性漸變的重復(fù)效果,使色標(biāo)在漸變線方向上無限重復(fù),實現(xiàn)一些特殊的效果
[注意]只有當(dāng)首尾兩顏色位置不在0%或100%時,重復(fù)漸變才生效
- background-image: -webkit-repeating-linear-gradient(blue 20%,green 50%);
- background-image: repeating-linear-gradient(blue 20%,green 50%);
紙張效果
使用重復(fù)漸變可以實現(xiàn)橫線紙張效果
- div{
- height: 200px;
- width:200px;
- font: 14px/20px '宋體';
- text-indent: 2em;
- background-image: -webkit-repeating-linear-gradient(#f9f9f9,#f9f9f9 9%,#ccc 10%);
- background-image: repeating-linear-gradient(#f9f9f9,#f9f9f9 9%,#ccc 10%);
- }
我是特別長的特別長的特
別長的特別長的特別長的特別長的特
別長的特別長的測試文字
多背景
使用多背景屬性,利用帶有透明度的漸變顏色給圖片添加漸變的透明效果
- background: linear-gradient(rgba(255,255,255,0),rgba(255,255,255,0.8)),url('http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/img1.gif');
應(yīng)用場景
在CSS樣式中,漸變相當(dāng)于背景圖片,在理論上可在任何使用url()值的地方采用。比如最常見的background-image、list-style-image以及border-image。但目前為止,僅在背景圖片中得到完美的支持
【1】background-image
- background-image: -webkit-linear-gradient(pink,lightblue,lightgreen);
- background-image: linear-gradient(pink,lightblue,lightgreen);
[注意]漸變框的大小由background-size決定,默認(rèn)是padding box
【2】list-style-image
- list-style-image: -webkit-linear-gradient(red,blue);
- list-style-image: linear-gradient(red,blue);
- font-size: 50px;
[注意]漸變框的大小由font-size決定,默認(rèn)是1em
[注意]firefox不支持在list-style-image中設(shè)置
【3】border-image
- -webkit-border-image: -webkit-linear-gradient(black,green) 1/10px;
- border-image: linear-gradient(black,green) 1/10px;
[注意]漸變框的大小由borer-width決定,safari瀏覽器始終實現(xiàn)的都是帶有fill參數(shù)的表現(xiàn)
IE兼容
IE9-瀏覽器并不支持該屬性,但可以使用IE準(zhǔn)專有的濾鏡語法來實現(xiàn)兼容
- filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='#color', endColorstr='#color');GradientType代表漸變線方向,0為垂直(默認(rèn)),1為水平
- #color代表色標(biāo),格式是#aarrggbb,其中aa為透明度,rrggbb為rgb模式的顏色
- startColorstr的默認(rèn)值是#ff0000ff
- endColorstr的默認(rèn)值是#ff000000
[注意]由于IE濾鏡只支持首尾兩個位置,且方向只可以為垂直和水平,所以有很大的局限性
- filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='#ff0000ff', endColorstr='#ffff00ff');
以上這篇深入剖析CSS中的線性漸變linear-gradient就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
原文地址:http://www.cnblogs.com/xiaohuochai/archive/2016/04/12/5370446.html
相關(guān)文章
CSS 實現(xiàn)漸變效果小結(jié)( linear-gradient線性漸變 和 radial-gradient徑
這篇文章主要介紹了CSS 實現(xiàn)漸變效果的代碼( linear-gradient線性漸變 和 radial-gradient徑向漸變),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的2020-04-16CSS3 linear-gradient線性漸變生成加號和減號的方法
本篇文章主要介紹了CSS3 linear-gradient線性漸變生成加號和減號的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-21CSS3,線性漸變(linear-gradient)的使用總結(jié)
今天這篇文章我們在一起來看看 CSS3 中實現(xiàn)漸變效果的 Gradient 屬性的具體用法。在以前,漸變效果和陰影、圓角效果一樣都是做成圖片,直接編寫 CSS 代碼就可以實現(xiàn)。2017-01-09- 這篇文章主要為大家詳細(xì)介紹了CSS3 漸變(Gradients)之CSS3 線性漸變的相關(guān)資料,了解學(xué)習(xí)CSS3 線性漸變,感興趣的小伙伴們可以參考一下2016-07-08
利用CSS3的線性漸變linear-gradient制作邊框的示例
linear-gradient線條用來制作邊框還是比較給力的,尤其是利用其描邊可以制作一些復(fù)制的邊框效果,這里我們就來看一下利用CSS3的線性漸變linear-gradient制作邊框的示例2016-06-02- 這篇文章主要介紹了CSS3中顏色線性漸變實戰(zhàn),示例中展示了代碼設(shè)置不同漸變方向的效果,需要的朋友可以參考下2015-07-18
- 這篇文章主要介紹了CSS3中線性顏色漸變的一些實現(xiàn)方法,包括分Safari和Chrome的webkit內(nèi)核與Firefox的Gecko內(nèi)核兩種情況,需要的朋友可以參考下2015-07-14
- 這篇文章主要介紹了CSS3實現(xiàn)線性漸變用法詳解,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-07