神奇的 conic-gradient圓環(huán)漸變

conic-gradient 是個什么?說到conic-gradient ,就不得不提的它的另外兩個兄弟:
  • linear-gradient : 線性漸變


    linear-gradient : 線性漸變
  • radial-gradient : 徑向漸變
radial-gradient : 徑向漸變

說這兩個應該還是有很多人了解并且使用過的。CSS3 新增的線性漸變及徑向漸變給 CSS 世界帶來了很大的變化。

而 conic-gradient ,表示圓錐漸變,另外一種漸變方式,給 CSS 世界帶來了更多可能。

API

{
    /* Basic example */
    background: conic-gradient(deeppink, yellowgreen);
}
conic-gradient
與線性漸變及圓錐漸變的異同
  • linear-gradient 線性漸變的方向是一條直線,可以是任何角度
  • radial-gradient徑向漸變是從圓心點以橢圓形狀向外擴散
而從方向上來說,圓錐漸變的方向是這樣的:

起始點是圖形中心,然后以順時針方向繞中心實現(xiàn)漸變效果

在項目中使用 conic-gradient

看看下面這個圖,芝麻信用分背景漸變顏色條,不使用 JS,純 CSS 借助 conic-gradient 如何畫出來。


conic-gradient

假設我們的結構如下:

<div class="bg">
    <div class="point"></div>
</div>

CSS:

.bg {
position: relative;
margin: 50px auto;
width: 400px;
height: 400px;
border-radius: 50%;
background: conic-gradient(#f1462c 0%, #fc5d2c 12.4%, #fff 12.5%, #fff 12.5%, #fc5d2c 12.5%, #fba73e 24.9%, #fff 24.9%, #fff 25%, #fba73e 25%, #e0fa4e 37.4%, #fff 37.4%, #fff 37.5%, #e0fa4e 37.5%, #12dd7e 49.9%, #fff 49.9%, #fff 50%, #12dd7e 50%, #0a6e3f 62.4%, #fff 62.4%, #fff 62.5%);
transform: rotate(-112.5deg);
transform-origin: 50% 50%;
}

.bg::before {
content: "";
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
width: 370px;
height: 370px;
border-radius: 50%;
background: #fff;
}

.bg::after {
content: "";
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
width: 320px;
height: 320px;
border-radius: 50%;
background:
    radial-gradient(#fff 0%, #fff 25%, transparent 25%, transparent 100%),
    conic-gradient(#f1462c 0 12.5%, #fba73e 0 25%, #e0fa4e 0 37.5%, #12dd7e 0 50%, #0a6e3f 0 62.5%, #fff 0 100%);
     
}

.point {
position: absolute;
width: 30px;
height: 30px;
transform: translate(-50%, -50%);
left: 50%;
top: 50%;
background: radial-gradient(#467dc6 0%, #a4c6f3 100%);
border-radius: 50%;
z-index: 999;
}

.point::before {
content: "";
position: absolute;
width: 5px;
height: 350px;
left: 50%;
top: 50%;
transform: translate(-50%, -50%) rotate(0);
border-radius: 100% 100% 5% 5%;
background: linear-gradient(
    180deg,
    #9bc7f6 0,
    #467dc6 50%,
    transparent 50%,
    transparent 100%
);
animation: rotate 3s cubic-bezier(.93, 1.32, .89, 1.15) infinite;
}

@keyframes rotate {
50% {
    transform: translate(-50%, -50%) rotate(150deg);
}
100% {
    transform: translate(-50%, -50%) rotate(150deg);
}
} 

為了凸顯 conic-gradient的實用性,簡單將二者合二為一,模擬了一下。看看效果,大功告成,所以說 conic-gradient 還是有用武之地的:

最終效果

圓錐漸變 conic-gradient polyfill 墊片庫

看到這里,想必大家都躍躍欲試這么神奇的屬性。

但是,按照慣例,這種 “高科技” 通常兼容性都不怎么滴。conic-gradient 兼容性又如何呢?

非常慘烈,CSS 官方對其的描述是:

處于修正階段的模塊沒有處于改善階段的模塊穩(wěn)定。通常它們的語法還需要詳細審查,說不定還會有很大的變化,而且不保證和之前的兼容。替代的語法通常經(jīng)過測試并已經(jīng)實現(xiàn)。

萬幸的是, LeaVerou 大神,讓我們可以提前使用上這么美妙的屬性。

LeaVerou 提供了一個墊片庫,按照本文上述的語法,添加這個墊片庫,就可以開心的使用起來啦。

polyfill 是一個開發(fā)術語,在 Web 開發(fā)中,polyfill 墊片庫的準確意思為:用于實現(xiàn)瀏覽器并不支持的原生API的代碼。現(xiàn)在引申為實現(xiàn)瀏覽器并不支持的某些功能的兼容庫。

你需要添加如下的 JS ,墊片庫會按照 CSS 語法,生成對應的圓錐漸變圖案,并且轉化為 BASE64 代碼:

<script src="http://cdnjs.cloudflare.com/ajax/libs/prefixfree/1.0.7/prefixfree.min.js"></script>
<script src="http://leaverou.github.io/conic-gradient/conic-gradient.js"></script>

因為墊片庫的作用是將我們的 CSS 語法轉化成為 BASE64 代碼替換 background-image: url() 中的內容,所以,上線后是不需要再添加這兩個庫的。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • -webkit-linear-gradient線形漸變詳解 CSS3發(fā)布很久了,現(xiàn)在在國外的一些頁面上常能看到他的...
    魏魏魏_1500閱讀 15,628評論 0 3
  • 1、屬性選擇器:id選擇器 # 通過id 來選擇類名選擇器 . 通過類名來選擇屬性選擇器 ...
    Yuann閱讀 1,656評論 0 7
  • 在用CSS實現(xiàn)等效中,經(jīng)常會用到漸變,所以,本篇就研究一下漸變的特性; 在CSS中,漸變并不是作為CSS中的一個屬...
    科研者閱讀 692評論 0 3
  • 常說道:計劃趕不上變化 往后希望自己成為無論工作,生活發(fā)生什么樣的變化都能從容應對,并且處理的游刃有余的人。
    _星晨閱讀 208評論 0 0
  • 聽到表哥阿合不回來過雞年的消息后,我的心里落寞了好久。 阿合是我姨家的孩子,比我大了五歲。從小我們就在一起玩。阿合...
    千尋凌霄閱讀 335評論 0 7