【css】css 背景色漸變兼容寫法


最近在項目中,有很多地方都用到了線性漸變,比如:表單提交按鈕的背景,數據展示的標題背景等等,按照以前的做法是切 1px 圖片然后 repeat-x。下面我將介紹如何用 css 來完成該效果。

css3:linear-gradient

比如:黑色漸變到白色,代碼如下:

.gradient{
    background: -moz-linear-gradient(top, #000000 0%, #ffffff 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#000000), color-stop(100%,#ffffff));
    background: -webkit-linear-gradient(top, #000000 0%,#ffffff 100%);
    background: -o-linear-gradient(top, #000000 0%,#ffffff 100%);
    background: -ms-linear-gradient(top, #000000 0%,#ffffff 100%);
    background: linear-gradient(to bottom, #000000 0%,#ffffff 100%);
}

說明:linear-gradient 具體用法點此進入

ie 濾鏡:filter

linear-gradient 在 ie9 以下是不支持的,所以對於 ie6 - ie8 我們可以使用濾鏡來解決,代碼如下:

.gradient{
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#000000', endColorstr='#ffffff',GradientType=0 );
}

由於 filter 是 ie 的私有屬性,所以我們需要針對 ie9 單獨處理濾鏡效果,代碼如下:

:root {filter:none;}

總結:

綜上所述,線性漸變的兼容寫法如下:

.gradient{
    background: #000000;
    background: -moz-linear-gradient(top,  #000000 0%, #ffffff 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#000000), color-stop(100%,#ffffff));
    background: -webkit-linear-gradient(top,  #000000 0%,#ffffff 100%);
    background: -o-linear-gradient(top,  #000000 0%,#ffffff 100%);
    background: -ms-linear-gradient(top,  #000000 0%,#ffffff 100%);
    background: linear-gradient(to bottom,  #000000 0%,#ffffff 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#000000', endColorstr='#ffffff',GradientType=0 );
}
:root .gradient{filter:none;}

PS:

在實際的項目中,往往會碰到圓角和漸變的組合,如果使用上面的寫法,那么在 ie9 下會有 bug(在 ie9 下背景色不能完全切完),解決方法是SVG,具體點此查看


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM