成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

10個demo示例學(xué)會CSS3radial-gradient徑向漸變

一、語法細節(jié)記不住怎么辦?
實際開發(fā)的時候,當(dāng)要使用radial-gradient徑向漸變的時候,腦中會有大概的語法,但是細節(jié)卻記不住,于是想快捷找個案例看看具體怎么用,然后直接套一下。通常一番搜索,會發(fā)現(xiàn)雖然是個簡單需求,但是正好滿足這個需求的頁面卻不好找,亂糟糟的。

從策劃到設(shè)計制作,每一步都追求做到細膩,制作可持續(xù)發(fā)展的企業(yè)網(wǎng)站。為客戶提供成都網(wǎng)站設(shè)計、成都做網(wǎng)站、網(wǎng)站策劃、網(wǎng)頁設(shè)計、國際域名空間、網(wǎng)站空間、網(wǎng)絡(luò)營銷、VI設(shè)計、 網(wǎng)站改版、漏洞修補等服務(wù)。為客戶提供更好的一站式互聯(lián)網(wǎng)解決方案,以客戶的口碑塑造優(yōu)易品牌,攜手廣大客戶,共同發(fā)展進步。

下次遇到這種場景,直接來本站搜“徑向漸變”,或者直接搜索“漸變”,就有專門展示radial-gradient徑向漸變基本語法使用案例的文章。文章共展示了10例常見使用案例,相信一定可以覆蓋你的使用場景的。

首先,假設(shè)我們使用同一段HTML作為示意:

<div class="radial-gradient"></div>

二、示例1:最基礎(chǔ)最簡單使用

CSS如下:

.radial-gradient {
    width: 400px; height: 200px;
    background: radial-gradient(yellow, red);
}

最終效果如下圖:

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

可見,對于徑向漸變,在不指定漸變類型以及位置的情況下,其漸變距離和位置是由容器的尺寸決定的。

例如本例之中,容器的寬高比是2:1,最終漸變呈現(xiàn)出來的形狀也是一個2:1的橢圓形,并且漸變顏色自動終止與容器的邊緣。

原理示意如下:

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

三、示例2:簡單的圓形漸變
CSS代碼如下:

.radial-gradient {
    width: 400px; height: 200px;
    background: radial-gradient(circle, yellow, red);
}

其漸變范圍(漸變結(jié)束線)示意如下圖,會發(fā)現(xiàn)既不是按照寬度來的,也不是按照高度來的,是按照最遠邊角距離作為漸變結(jié)束線的:

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

其漸變范圍(漸變結(jié)束線)示意如下圖,會發(fā)現(xiàn)既不是按照寬度來的,也不是按照高度來的,是按照最遠邊角距離作為漸變結(jié)束線的:

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

要證明上面結(jié)論比較簡單,我們可以計算下對角線一半長度,為:Math.sqrt(200 200 + 400 400) ≈ 223.6,于是,我們設(shè)置:

.radial-gradient {
    width: 400px; height: 200px;
    background: radial-gradient(223.6px circle, yellow, red);
}

會發(fā)現(xiàn),最終效果和上面的效果截圖幾乎就是一模一樣的。而200px的半徑:

.radial-gradient {
    width: 400px; height: 200px;
    background: radial-gradient(200px circle, yellow, red);
}

取色就會發(fā)現(xiàn)邊緣顏色差異較大,說明默認不是按照最短邊來渲染的。

四、示例3:指定漸變起始點位置
起始點位置可以通過at來指定,例如:

.radial-gradient {
    width: 400px; height: 200px;
    background: radial-gradient(circle at 50px 50px, yellow, red);
}

效果如下圖所示:

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

如果希望漸變是和容器保持一致比例的橢圓,則circle可以缺省,也就是直接radial-gradient(at 50px 50px, yellow, red)也是可以的。

50px 50px我們也可以使用百分比值代替,例如:

.radial-gradient {
    width: 400px; height: 200px;
    background: radial-gradient(circle at 12.5% 25%, yellow, red);
}

效果是一模一樣的。

五、示例4:指定漸變終止點位置
radial-gradient徑向漸變支持4個關(guān)鍵字可以指定漸變終止點位置,見下表:

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

根據(jù)上面的示意效果可以看出默認值是farthest-corner。

現(xiàn)在,我們對CSS進行調(diào)整,如下:

.radial-gradient {
    width: 400px; height: 200px;
    background: radial-gradient(closest-side circle at 50px 50px, yellow, red);
}

也就是圓形漸變終止于最短邊,結(jié)果效果如下圖:

六、示例5:指定漸變顏色斷點
如果指定多個顏色,但未指定具體斷點的位置,則這些顏色會均勻分配0%~100%的漸變區(qū)域,例如,下面4色漸變:

.radial-gradient {
    width: 200px; height: 200px;
    border: 1px solid silver;
    background: radial-gradient(closest-side circle, yellow, orange, red, white);
}

結(jié)果如下圖所示:

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

但從肉眼視覺我們是看不出是不是均勻分配漸變區(qū)域,但是我們可以通過其他方式驗證我們的觀點,如下指定顏色斷點位置的CSS:

.radial-gradient2 {
    width: 200px; height: 200px;
    border: 1px solid gray;
    background: radial-gradient(closest-side circle, yellow, orange 33.33%, red 66.666%, white);
}

由于漸變顏色默認第一個顏色位置是0%,最后一個顏色位置是100%,因此上面yellow和white的斷點位置可以缺省。

然后發(fā)現(xiàn)效果和上面的是一致的:

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

按下第一個圈圈漸變,會讓后面的圈圈瞬間覆蓋在上面。如果兩個漸變顏色有差異,此時肉眼可以感覺到明顯變化;但是實際操作下來,就好像后面漸變突然消失一般,這就說明上下兩個漸變實際上效果是一致的。

七、示例6:橢圓類型的徑向漸變
對于圓形界面,我們只需要指定一個半徑就可以了,但是對于橢圓類型的徑向漸變,我們需要同時指定橫軸和縱軸的長度,例如:

.radial-gradient {
    width: 200px; height: 200px;
    background: radial-gradient(50px 100px ellipse, transparent 40px, yellow 41px, red);
}

50px 100px ellipse中第一個數(shù)值50px表示橫軸半徑,100px表示縱軸半徑,于是這段語句表示繪制一個長度100px高度200px的橢圓。

效果如下圖:

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

需要注意的是,在上面示意CSS代碼中,透明到黃色分界那里有一個1px的偏差過渡,也就是transparent 40px, yellow 41px中yellow是41px,而不是設(shè)置的40px,原因在于在Chrome下,如果顏色直接0偏差過渡,會有比較嚴重的鋸齒,類似下圖這樣(背景色設(shè)為#333):

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

通過有1像素或者半像素的過渡緩沖可以有效避免鋸齒的出現(xiàn)。

八、示例7:可累加的徑向漸變背景圖
我們可以把多個徑向漸變累加在一起實現(xiàn)某些效果,例如下面CSS:

.radial-gradient {
    width: 200px; height: 200px;
    background: radial-gradient(50px 100px ellipse, transparent 40px, yellow 41px, red 49px, transparent 50px),
                radial-gradient(30px circle, red, red 29px, transparent 30px);
}

實現(xiàn)了“邪王真眼”效果:

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

九、示例8:漸變背景的尺寸控制
配合background-size的尺寸控制和背景重復(fù)特性,我們可以實現(xiàn)漸變式的復(fù)雜紋理效果:

.radial-gradient {
    width: 200px; height: 200px;
    background: radial-gradient(5px 10px ellipse, transparent 4px, yellow 5px, red 6px, transparent 7px),
                radial-gradient(3px circle, red, red 3px, transparent 4px);
    background-size: 25px;
}

于是就可以看到一大波寫輪眼:

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

通常我們使用徑向漸變構(gòu)建一些簡單實用圖形的時候,background-size往往是關(guān)鍵屬性,例如,我們要實現(xiàn)個水波效果,可以這樣:

.radial-gradient {
    width: 200px; height: 100px;
    background: red;
    position: relative;
}
.radial-gradient:after {
    content: '';
    position: absolute;
    height: 10px;
    left:0 ; right: 0;
    bottom: -10px;
    background: radial-gradient(20px 15px ellipse at top, red 10px, transparent 11px);
    background-size: 20px 10px;
}

然后就有下圖所示的效果:

10個demo示例學(xué)會CSS3 radial-gradient徑向漸變
image.png

十、示例9:可重復(fù)的徑向漸變
如果想要實現(xiàn)可重復(fù)的徑向漸變,亦可以使用原生的repeating-radial-gradient()方法,特別適合實現(xiàn)從中心擴散的光波效果。

然而,相比重復(fù)線性漸變repeating-linear-gradient()方法,repeating-radial-gradient()的實際應(yīng)用場景實際上很有限。因為,實際開發(fā)的時候,我們很少用到從中心擴散的光波效果。

除了一些本身就是波紋類型效果,如水波,聲波或者唱片紋理:

如下CSS

.radial-gradient {
    position: relative;
    width: 262px; height: 262px;
    border-radius: 50%;
    background: linear-gradient(30deg, transparent 40%, rgba(42, 41, 40, .85) 40%) no-repeat 100% 0, linear-gradient(60deg, rgba(42, 41, 40, .85) 60%, transparent 60%) no-repeat 0 100%, repeating-radial-gradient(#2a2928, #2a2928 4px, #ada9a0 5px, #2a2928 6px);
    background-size: 50% 100%, 100% 50%, 100% 100%;
}
.radial-gradient:after {
    position: absolute;
    top: 50%; left: 50%;
    margin: -35px;
    border: solid 1px #d9a388;
    width: 68px; height: 68px;
    border-radius: 50%;
    box-shadow: 0 0 0 4px #da5b33, inset 0 0 0 27px #da5b33;
    background: #b5ac9a;
    content: '';
}

十一、示例10:作為border-image的徑向漸變
徑向漸變不僅可以作為background的背景圖,還可以作為border-image的邊框圖使用。

例如:

.radial-gradient {
    width: 100px; height: 100px;
    border: 50px solid;
    border-image: radial-gradient(circle, transparent 50px, yellow 51px, red) 50 stretch;
}

天然鏤空效果,只可惜border-image是無法和border-radius同時生效的,否則,border-image可就要牛炸天了。

結(jié)束語

這里推薦一下我的前端學(xué)習(xí)交流群:731771211 ,里面都是學(xué)習(xí)前端的,如果你想制作酷炫的網(wǎng)頁,想學(xué)習(xí)知識。自己整理了一份2019最全面前端學(xué)習(xí)資料,從最基礎(chǔ)的HTML+CSS+JS到移動端HTML5到項目實戰(zhàn)的學(xué)習(xí)資料都有整理,送給每一位前端小伙伴,有想學(xué)習(xí)web前端的,或是轉(zhuǎn)行,或是大學(xué)生,還有工作中想提升自己能力的,正在學(xué)習(xí)的小伙伴歡迎加入學(xué)習(xí)。 

文章題目:10個demo示例學(xué)會CSS3radial-gradient徑向漸變
文章出自:http://jinyejixie.com/article36/gciosg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄網(wǎng)站營銷、網(wǎng)頁設(shè)計公司、服務(wù)器托管、網(wǎng)站設(shè)計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)
榆树市| 景谷| 资源县| 道真| 丹寨县| 和龙市| 平山县| 德兴市| 三原县| 炎陵县| 华宁县| 车致| 扬中市| 罗源县| 桂阳县| 昭觉县| 凤山市| 泸水县| 汕尾市| 蒙城县| 衡山县| 闵行区| 灌南县| 织金县| 漯河市| 垦利县| 汪清县| 宝坻区| 府谷县| 开鲁县| 拉萨市| 平和县| 若羌县| 莱州市| 奎屯市| 北安市| 龙门县| 札达县| 景泰县| 南京市| 铜山县|