深入理解CSS線性漸變linear-gradient

来源:http://www.cnblogs.com/xiaohuochai/archive/2016/04/12/5370446.html
-Advertisement-
Play Games

× 目錄 [1]定義 [2]漸變線 [3]色標 [4]重覆漸變 [5]多背景 [6]應用場景 [7]IE相容 前面的話 在CSS3出現之前,漸變效果只能通過圖形軟體設計圖片來實現,可拓展性差,還影響性能。如今已經進入CSS3標準的漸變可以很輕鬆的完成漸變效果。漸變實際上分為線性漸變和徑向漸變兩種,本 ...


×
目錄
[1]定義 [2]漸變線 [3]色標 [4]重覆漸變 [5]多背景 [6]應用場景 [7]IE相容

前面的話

   在CSS3出現之前,漸變效果只能通過圖形軟體設計圖片來實現,可拓展性差,還影響性能。如今已經進入CSS3標準的漸變可以很輕鬆的完成漸變效果。漸變實際上分為線性漸變和徑向漸變兩種,本文介紹線性漸變。

 

定義

  漸變實際上是兩種或多種顏色之間的平滑過渡。而線性漸變是多種顏色沿著一條直線(稱為漸變線)過渡。漸變的實現由兩部分組成:漸變線和色標。漸變線用來控制發生漸變的方向;色標包含一個顏色值和一個位置,用來控制漸變的顏色變化。瀏覽器從每個色標的顏色淡出到下一個,以創建平滑的漸變,通過確定多個色標可以製作多色漸變效果。

  [註意]safari4-5、IOS3.2-4.3、android2.1-3只支持線性漸變,且需要添加-webkit-;safari5.1-6、IOS5.1-6.1、android4-4.3支持線性和徑向漸變,且需要添加-webkit-;IE10+及其他高版本瀏覽器支持標準寫法

<linear-gradient> = linear-gradient([ [ <angle> | to <side-or-corner> ] ,]? <color-stop>[, <color-stop>]+)
<side-or-corner> = [left | right] || [top | bottom]

 

漸變線

  漸變線從漸變框中心向兩個方向進行拓展,起點和終點是漸變線與經過漸變框的一個角的垂直線的相交點

  漸變的第一個參數用於指定漸變線,預設是to bottom。有兩種方式指定漸變線方向

【1】使用角度

  0deg表示沿著元素的中心線由下向上的方向(類似於y軸),且正角度表示順時針旋轉

  [註意]對於-webkit-舊版本瀏覽器,如windows系統下的safari瀏覽器來說,0deg表示沿著元素中心線從左向右的方向(類似於x軸),且正角度表示逆時針旋轉

  所以-webkit-舊版本瀏覽器與標準瀏覽器的之間線性漸變的角度關係為

-webkit-瀏覽器 = 90deg - 標準瀏覽器
相當於
-webkit-linear-gradient(90deg,red,blue) = linear-gradient(0deg,red,blue)

  [註意]對於webkit內核的瀏覽器來說,使用javascript改變元素的樣式。當帶-webkit-的私有樣式和不帶-webkit-的標準樣式同時存在的時候,並不一定是後面覆蓋前面。所以如果兩種寫法產生的效果相同,但參數不同時,要使用瀏覽器識別來分別寫不同的情況。

【2】使用關鍵字

to top -> 0deg
to right -> 90deg
to bottom -> 180deg
to left -> -90deg(或270deg)
to top left -> -45deg(或315deg)
to top right -> 45deg
to bottom left -> -135deg(或225deg)
to bottom right -> 135deg

  [註意]window系統的safari瀏覽器並不支持'to'加方向的關鍵字,如to left。它只支持方向關鍵字,如left。當然了left 和 to left 方向是正好相反的

 

色標

  瀏覽器對於色標並沒有預設值,且必須設置至少兩個色標。色標由顏色和位置組成。顏色使用任何一種顏色模式都可以,而位置可以使用百分比或數值。

  [註意]顏色的位置也可以設置負值

【1】必須是顏色在前,位置在後

//正確
background-image: linear-gradient(red 0%,blue 100%);
//錯誤
background-image: linear-gradient(0% red,100% blue);

【2】位置可以省略,瀏覽器預設會把第一個顏色的位置設置為0%,把最後一個顏色的位置設置為100%

background-image: linear-gradient(red 0%,blue 100%);
//等價於上一個
background-image: linear-gradient(red,blue);

【3】若漸變只有兩種顏色,且第一個顏色的位置設置為n%,第二個顏色的位置設置為m%。則瀏覽器會將0%-n%的範圍設置為第一個顏色的純色,n%-m%的範圍設置為第一個顏色到第二個顏色的過渡,m%-100%的範圍設置為第二個顏色的純色

background-image: linear-gradient(red 30%,blue 60%);
//等價於上一個
background-image: linear-gradient(red 0%,red 30%,blue 60%,blue 100%);

【4】若漸變顏色沒有指定位置,則它們會均勻分佈

background-image: linear-gradient(red,yellow,green,blue);

【5】若多色占據同一個位置,例a、b、c三色均占據n%這一位置,則0%-n%為前一種顏色與a顏色的顏色漸變;然後是n%-n%的a顏色與c顏色的顏色突變;n%-100%是c顏色與後一種顏色的顏色漸變。因此,中間的b是無用的

background-image: linear-gradient(red,yellow 50%,white 50%,black 50%,blue);
//等價於上一個
background-image: linear-gradient(red,yellow 50%,black 50%,blue);

 

重覆漸變

  重覆漸變可以實現線性漸變的重覆效果,使色標在漸變線方向上無限重覆,實現一些特殊的效果

  [註意]只有當首尾兩顏色位置不在0%或100%時,重覆漸變才生效

background-image: -webkit-repeating-linear-gradient(blue 20%,green 50%);
background-image: repeating-linear-gradient(blue 20%,green 50%);

紙張效果

  使用重覆漸變可以實現橫線紙張效果  

div{
    height: 200px;
    width:200px;
    font: 14px/20px '宋體';
    text-indent: 2em;
    background-image: -webkit-repeating-linear-gradient(#f9f9f9,#f9f9f9 9%,#ccc 10%);
    background-image: repeating-linear-gradient(#f9f9f9,#f9f9f9 9%,#ccc 10%);
}

 

多背景

  使用多背景屬性,利用帶有透明度的漸變顏色給圖片添加漸變的透明效果

background: linear-gradient(rgba(255,255,255,0),rgba(255,255,255,0.8)),url('http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/img1.gif');

 

應用場景

  在CSS樣式中,漸變相當於背景圖片,在理論上可在任何使用url()值的地方採用。比如最常見的background-image、list-style-image以及border-image。但目前為止,僅在背景圖片中得到完美的支持

【1】background-image

background-image: -webkit-linear-gradient(pink,lightblue,lightgreen);
background-image: linear-gradient(pink,lightblue,lightgreen);

  [註意]漸變框的大小由background-size決定,預設是padding box

【2】list-style-image

list-style-image: -webkit-linear-gradient(red,blue);
list-style-image: linear-gradient(red,blue);
font-size: 50px;

  [註意]漸變框的大小由font-size決定,預設是1em 

  [註意]firefox不支持在list-style-image中設置

【3】border-image

-webkit-border-image:  -webkit-linear-gradient(black,green) 1/10px;    
border-image:  linear-gradient(black,green) 1/10px;

  [註意]漸變框的大小由borer-width決定,safari瀏覽器始終實現的都是帶有fill參數的表現

 

IE相容

  IE9-瀏覽器並不支持該屬性,但可以使用IE準專有的濾鏡語法來實現相容

filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='#color', endColorstr='#color');
GradientType代表漸變線方向,0為垂直(預設),1為水平
#color代表色標,格式是#aarrggbb,其中aa為透明度,rrggbb為rgb模式的顏色
startColorstr的預設值是#ff0000ff 
endColorstr的預設值是#ff000000

  [註意]由於IE濾鏡只支持首尾兩個位置,且方向只可以為垂直和水平,所以有很大的局限性

filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='#ff0000ff', endColorstr='#ffff00ff');


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 上一篇文章介紹瞭如何利用CSS選擇器為元素應用各種豐富的樣式,每個合法的文檔都會生成一個結構樹,瞭解這一點,就能根據元素的祖先、屬性、兄弟等元素穿件選擇器選擇元素。 本篇文章將討論3中機制之間的關係:特殊性、繼承和層疊 特殊性 有的時候我們為同一個元素設置了不同的CSS樣式代碼,那麼元素會啟用哪一個 ...
  • 打包的目的和意義就不用敘述了直接上乾貨 http://www.gruntjs.net/getting-started裡面的教程也太簡單了,需要下一番功夫去研究才行。本文將grunt打包的常用方法都用實例描述,更加清晰易懂。 1. 第一個簡單的grunt打包 1)需要安裝nodejs:http://w ...
  • 所謂的瀏覽器相容性問題,是指因為不同的瀏覽器對同一段代碼有不同的解析,造成頁面顯示效果不統一的情況。在大多數情況下,我們的需求是,無論用戶用什麼瀏覽器來查看我們的網站或者登陸我們的系統,都應該是統一的顯示效果。所以瀏覽器的相容性問題是前端開發人員經常會碰到和必須要解決的問題。 在學習瀏覽器相容性之前 ...
  • sublime text3 是個很好的編輯工具,前端程式員覺得她很好,我是在一次視頻中看到她能幫助自動完成很多快捷的操作。 為什麼安裝? 如果想要給sublime text 中安裝別的插件(這裡稱呼為 包),那麼首先得先給她安裝個插件管理器,也就是包管理器 package control 怎麼安裝她... ...
  • 值得打一個helloworld好好紀念一下! <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Document</title></head><body> <strong>HELLO WORLD</strong>< ...
  • 區分 DOM 屬性和元素屬性 區分 DOM 屬性和元素屬性 通常開發人員習慣將id,src,alt等叫做這個元素的"屬性"。我們將其稱為"元素屬性"。但是在解析成 DOM 對象時,實際瀏覽器最後會將標簽元素解析成"DOM 對象", 並且將元素的"元素屬性"存儲為"DOM 屬性",兩者是有區別的。 甚 ...
  • 《超實用的Node.js代碼段》連載一:獲取Buffer對象位元組長度 《超實用的Node.js代碼段》連載二:正確拼接Buffer Node.js是一種後起的優秀伺服器編程語言,它用來構建和運行Web應用,這和ASP.NET,Ruby on Rails或Spring框架做的工作是類似的。它使用Jav ...
  • 今天在使用bootbox做彈出提示遇到些麻煩,由於使用kendoWindow先彈出數據輸入視窗, 然後在檢核輸入時,又用bootbox做為提示視窗,這下悲劇了,後彈出的bootbox視窗總是在kendoWindow後面, 查了兩者的API文檔,均沒有設置的地方,木有辦法,只能自己搞了,使用調試工具查 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...