溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

CSS如何實(shí)現(xiàn)漸變

發(fā)布時(shí)間:2021-08-03 10:34:37 來源:億速云 閱讀:161 作者:小新 欄目:web開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)CSS如何實(shí)現(xiàn)漸變,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

一、線性漸變

這里需要大家先去看一下基本語法,再看接下來的例子。

linear-gradient(90deg,red 20%,blue 50%,yellow 80%);

CSS如何實(shí)現(xiàn)漸變

很顯然通過這張圖,你會(huì)大概的明白設(shè)置這些參數(shù)的作用。雖然我并沒有用什么文字去解釋它。(所以當(dāng)你看不明白定義的時(shí)候,一定要實(shí)踐。)
接下來,我們要搞點(diǎn)事情。我們將顏色的分隔點(diǎn)重疊。

width: 300px;
    height: 200px;
    background: linear-gradient(90deg,blue 100px,#fff 100px,#fff 200px,red 200px);

CSS如何實(shí)現(xiàn)漸變

沒錯(cuò)這就是上述漸變代碼產(chǎn)生的效果,是不是感覺打破你以前對(duì)漸變的印象。
 

下面我們利用linear-gradient實(shí)現(xiàn)更酷的效果,比如:

CSS如何實(shí)現(xiàn)漸變
 

是不是感覺已經(jīng)突破自己對(duì)漸變的認(rèn)識(shí)。讓我來說一下實(shí)現(xiàn)這個(gè)背景的思路:這是個(gè)有規(guī)律的圖案,我們要找到它的基本圖案,我相信你已經(jīng)找到了。
 

我們需要用到的知識(shí)點(diǎn):

  • background支持聲明多個(gè)linear-gradient,通過逗號(hào)分隔;

  • 當(dāng)你聲明多個(gè)linear-gradient,最先聲明的,離用戶越近。(這里就需要我們考慮遮蓋的問題,一般采用transparent);

  • 還沒掌握background的簡(jiǎn)寫方式,可是不行的哦;

  • background-repeat、background-size和background-position的合理結(jié)合。

width: 410px;
    height: 410px;
    background: linear-gradient(rgb(2,222,222) 10px, transparent 10px) repeat left top / 40px,
                linear-gradient(90deg,rgb(2,222,222) 10px, transparent 10px) repeat left top / 40px;

你看看,以前實(shí)現(xiàn)這樣的效果,我們只能苦苦哀求美工切圖,現(xiàn)在在CSS3的浪潮中,我們可以自給自足(^_^)。
 

而且通過漸變我們可以實(shí)現(xiàn)背景顏色的動(dòng)畫,而不需要消耗額外的HTML元素達(dá)到我們預(yù)期的效果。例子:

CSS如何實(shí)現(xiàn)漸變
 

/*
     *  這里用scss寫的,對(duì)新手不太友好,抱歉(-_-)
     */
    @mixin menuaction($color) {
        background: linear-gradient($color 100%, transparent 100%) no-repeat center bottom / 100% 10%;
        &:hover {
            background-size: 100% 100%;
            color: #fff;
        }
    }

二、徑向漸變

基本上徑向漸變與線性漸變差不多,只不過它是由中心點(diǎn)向外擴(kuò)散。所以我這里就不再贅述。
 

話不多說,先畫個(gè)同心圓:

CSS如何實(shí)現(xiàn)漸變
 

border-radius: 50%;
    background: radial-gradient(circle,rgb(22,222,111) 0,rgb(22,222,111) 50px,red 50px,red 100px, rgb(222,222,1) 100px, rgb(222,222,1) 150px,rgb(222,2,111) 150px);

最后以什么結(jié)束呢,哈哈最近各種優(yōu)惠券,那我們用漸變的知識(shí)來搞張優(yōu)惠券吧:

CSS如何實(shí)現(xiàn)漸變
 

核心代碼如下:

width: 300px;
    height: 120px;
    background: radial-gradient(transparent 0, transparent 5px, rgb(247,245,201) 5px) no-repeat,
                radial-gradient(transparent 0, transparent 5px, rgb(247,245,201) 5px) no-repeat,
                radial-gradient(transparent 0, transparent 5px, rgb(247,245,201) 5px) no-repeat,
                radial-gradient(transparent 0, transparent 5px, rgb(247,245,201) 5px) no-repeat,
                radial-gradient(transparent 0, transparent 5px, rgb(247,245,201) 5px) no-repeat,
                radial-gradient(transparent 0, transparent 5px, rgb(247,245,201) 5px) no-repeat,
                radial-gradient(#fff 0, #fff 10px, rgb(247,245,201) 10px) no-repeat,
                radial-gradient(#fff 0, #fff 10px, rgb(247,245,201) 10px) no-repeat,
                linear-gradient(90deg,transparent 10px, rgb(247,245,201) 10px);
            background-size: 20px 20px,20px 20px,20px 20px,20px 20px,20px 20px,20px 20px,60px 60px,60px 60px,100% 100%;
            background-position: -10px 0,-10px 20px,-10px 40px,-10px 60px,-10px 80px,-10px 100px,60px -30px,60px 90px,left center;

關(guān)于“CSS如何實(shí)現(xiàn)漸變”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

css
AI