一区二区三区中文国产亚洲_另类视频区第一页_日韩精品免费视频_女人免费视频_国产综合精品久久亚洲

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 如何用css實現(xiàn)漸變

如何用css實現(xiàn)漸變

來源:千鋒教育
發(fā)布人:wjy
時間: 2022-09-06 17:32:00 1662456720

css中可以進行背景的漸變,通常來說,我們使用的是下面兩種漸變

- 線性漸變
- 徑向漸變

## **線性漸變**

先來看一下語法:

```text
linear-gradient(
  [ <angle> | to <side-or-corner> ,]? <color-stop-list> )
  \---------------------------------/ \----------------------------/
    Definition of the gradient line        List of color stops
```

解釋一下:

- <angle> 角度值指定漸變的方向(或角度)。
- <side-or-corner> 漸變線的起始點位置。它包含to和兩個關鍵詞:第一個指出水平位置left or right, 第二個指出垂直位置top or bottom。關鍵詞的先后順序無影響,且都是可選的。
- <color-stop> 由一個`<color>`值組成,并且跟隨著一個可選的終點位置(可以是一個百分比值或者是沿著漸變軸的`<length>`

于是我們有了下面的效果:

![img](https://pic4.zhimg.com/80/v2-a5619a524d2867fb87026426dbe3394b_720w.jpg)

這是一個從左到右的金色到粉色的線性漸變

```css
background-image: linear-gradient(to right, gold, pink)
```

## **徑向漸變**

先來看下語法:

```css
radial-gradient(
  [ [ circle || <length> ]                         [ at <position> ]? , |
    [ ellipse || [ <length> | <percentage> ]{2} ]  [ at <position> ]? , |
    [ [ circle | ellipse ] || <extent-keyword> ]   [ at <position> ]? , |
    at <position> ,
  ]?
  <color-stop> [ , <color-stop> ]+
)
```

或者我們可以簡化成下面這樣:

```text
radial-gradient(shape size position, color-stop[...,color-stop]);
```

解釋一下:

- <position> 徑向漸變的圓心位置
- <shape> 漸變的形狀。圓形(漸變的形狀是一個半徑不變的正圓)或橢圓形(軸對稱橢圓)。默認值為橢圓
- <size> 漸變的尺寸大小
- <color-stop> 由一個<color>值組成,并且跟隨著一個可選的終點位置(可以是一個百分比值或者是沿著漸變軸的<length>

CSS實現(xiàn)漸變

 

于是我們有了下面的效果:

![img](https://pic1.zhimg.com/80/v2-3be59a375a924c39d2106566a79cd760_720w.jpg)

這是一個紅色到黑色的徑向漸變

```text
background-image: radial-gradient(red,black)
```

## **漸變的花式玩法**

當然上面的漸變是非常簡單的玩法,下面我們整點高難度的~

- 顏色突變

我們當前做的漸變是一個均勻的漸變,如果多個顏色具有相同的位置,那么這些顏色就會在一個無限小的過渡區(qū)域進行過渡,從視覺上看,顏色在該位置就會突然變化,而不是一個平滑的過渡效果。

就像這樣

![img](https://pic3.zhimg.com/80/v2-71dfdfc0da9060d08d47fd33ee6a1a02_720w.jpg)

- 背景的多個屬性配合

漸變可以當背景圖去處理,既然是背景圖,那么就可以進行疊加和平鋪,于是我們得到了下面的效果:

![img](https://pic4.zhimg.com/80/v2-36c1d5925ca15e4b241f1ddc0496d0eb_720w.jpg)

這是兩個漸變疊加配合背景圖平鋪實現(xiàn)的效果

```css
background-image:
                linear-gradient(rgba(255,0,0,0.5) 50% ,transparent 50%),
                linear-gradient(to right,rgba(255,0,0,0.5) 50% , #fff 50% );
background-size: 50px 50px;
```

我們也可以用重復線性漸變進行疊加操作:

![img](https://pic4.zhimg.com/80/v2-ce60500da4345794188498c20d32c753_720w.jpg)

```css
background-image:
                repeating-linear-gradient(-45deg,
                    transparent,
                    transparent 25%,
                    tomato 0,
                    tomato 50%),
                repeating-linear-gradient(45deg,
                    transparent,
                    transparent 25%,
                    dodgerblue 0,
                    dodgerblue 50%), wheat;

background-size: 50px 50px;
```

再加上億點細節(jié)~ (background-blend-mode: multiply; 正片疊底效果)

就是這個樣子啦!Ta Da!

![img](https://pic2.zhimg.com/80/v2-07266c3b1f6a614d54e1967c39ed8545_720w.jpg)

- 漸變色的文字!

`-webkit-background-clip:text` 這個屬性可以將背景色裁剪到文字中,然后我們先這樣再這樣最后那樣就得到一個很棒的漸變色的文字!

![img](https://pic1.zhimg.com/80/v2-570ef762003a8b7400dad4f7f465dc78_720w.jpg)

```css
 color: transparent;
 background:
            repeating-linear-gradient(-45deg,
            transparent,
            transparent 25%,
            tomato 0,
            tomato 50%),
            repeating-linear-gradient(45deg,
            transparent,
            transparent 25%,
            dodgerblue 0,
            dodgerblue 50%), wheat;
background-size: 50px 50px;
background-blend-mode: multiply;
-webkit-background-clip: text;
```

- 漸變的邊框

利用`border-image-source` 屬性可以把漸變放在邊框中,像這樣:

![img](https://pic2.zhimg.com/80/v2-2ea9b68cc27a4a15794b7f8986cc9e75_720w.jpg)

```css
border: 20px solid;
border-image-source:
   repeating-linear-gradient(-45deg,
   cyan 0,
   cyan 15px,
   transparent 15px,
                        transparent 30px,
                        tomato 30px,
                        tomato 45px,
                        transparent 45px,
                        transparent 60px);

border-image-slice: 20;
```

更多關于“web前端培訓”的問題,歡迎咨詢千鋒教育在線名師。千鋒已有十余年的培訓經(jīng)驗,課程大綱更科學更專業(yè),有針對零基礎的就業(yè)班,有針對想提升技術的提升班,高品質(zhì)課程助理你實現(xiàn)夢想。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉載。
10年以上業(yè)內(nèi)強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
軟件開發(fā)管理流程中會出現(xiàn)哪些問題?

一、需求不清需求不明確是導致項目失敗的主要原因之一。如果需求沒有清晰定義,開發(fā)人員可能會開發(fā)出不符合用戶期望的產(chǎn)品。二、通信不足溝通問...詳情>>

2023-10-14 13:43:21
軟件定制開發(fā)中的敏捷開發(fā)是什么?

軟件定制開發(fā)中的敏捷開發(fā)是什么軟件定制開發(fā)中的敏捷開發(fā),從宏觀上看,是一個高度關注人員交互,持續(xù)開發(fā)與交付,接受需求變更并適應環(huán)境變化...詳情>>

2023-10-14 13:24:57
什么是PlatformIo?

PlatformIO是什么PlatformIO是一個全面的物聯(lián)網(wǎng)開發(fā)平臺,它為眾多硬件平臺和開發(fā)環(huán)境提供了統(tǒng)一的工作流程,有效簡化了開發(fā)過程,并能兼容各種...詳情>>

2023-10-14 12:55:06
云快照與自動備份有什么區(qū)別?

1、定義和目標不同云快照的主要目標是提供一種快速恢復數(shù)據(jù)的方法,它只記錄在快照時間點后的數(shù)據(jù)變化,而不是所有的數(shù)據(jù)。自動備份的主要目標...詳情>>

2023-10-14 12:48:59
服務器為什么要用Linux?

服務器為什么要用Linux作為服務器操作系統(tǒng)的優(yōu)選,Linux在眾多選擇中脫穎而出。Linux作為服務器操作系統(tǒng)的優(yōu)選,有其獨特的優(yōu)勢和特點。包括其...詳情>>

2023-10-14 12:34:11