首頁  >  文章  >  web前端  >  CSS之巧用漸層

CSS之巧用漸層

php中世界最好的语言
php中世界最好的语言原創
2018-03-21 16:59:481749瀏覽

這次帶給大家CSS之巧用漸變,CSS使用漸變注意事項有哪些,下面就是實戰案例,一起來看一下。

前言

本文主要分享了關於CSS3中linear-gradient和radial-gradient的相關知識,帶給大家使用漸變的另一個角度。有興趣的朋友們下面來一起看看詳細的介紹:
 

一、線性漸層

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

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

很顯然透過這張圖,你會大概的明白設定這些參數的作用。雖然我並沒有用什麼文字去解釋它。 (所以當你看不明白定義的時候,一定要實踐。)

接下來,我們要搞點事情。我們將顏色的分隔點重疊。

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

沒錯這就是上述漸層程式碼產生的效果,是不是感覺打破你以前對漸層的印象。

 

下面我們利用linear-gradient實現更酷的效果,例如:

 

是不是覺得已經突破自己對漸變的認識。讓我來談談這個背景的想法:這是一個有規律的圖案,我們要找到它的基本圖案,我相信你已經找到了。

 

我們需要用到的知識點:

  • #background支援宣告多個linear-gradient,透過逗號分隔;

  • 當你宣告多個linear-gradient,最先宣告的,離使用者越近。 (這裡就需要我們考慮遮蓋的問題,一般採用transparent);

  • #還沒掌握background的簡寫方式,可是不行的哦;


background-repeatbackground-size

background-position的合理結合。

    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;
你看看,以前實現這樣的效果,我們只能苦苦哀求美工切圖,現在在CSS3的浪潮中,我們可以自給自足(^_^)。  

而且透過漸層我們可以實現背景顏色的動畫,而不需要消耗額外的
HTML元素

達到我們預期的效果。例:

 

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

二、徑向漸層

基本上是徑向漸層與線性漸層差不多,只不過它是由中心點向外擴散。所以我這裡就不再贅述。
 

話不多說,先畫個同心圓:

 

    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);

最後以什麼結束呢,哈哈最近各種優惠券,那我們用漸變的知識來搞張優惠券吧: 

核心代碼如下:

    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;
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
推薦閱讀:############你不知道的冷門CSS屬性###############href和src、 link和@import有什麼差別#########

以上是CSS之巧用漸層的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn