整合營銷服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          css文字顏色漸變的3種實(shí)現(xiàn)

          者:IT智云編程

          鏈接:https://www.jianshu.com/p/4fa116fc4653

          在web前端開發(fā)過程中,UI設(shè)計(jì)師經(jīng)常會(huì)設(shè)計(jì)一些帶漸變文字的設(shè)計(jì)圖,在以前我們只能用png的圖片來代替文字,今天可以實(shí)現(xiàn)使用純CSS實(shí)現(xiàn)漸變文字了。下面就介紹3中實(shí)現(xiàn)方式供大家參考!

          基礎(chǔ)樣式:

          .gradient-text{text-align: left;text-indent:30px;line-height: 50px;font-size:40px;font-weight:bolder; position: relative; }
          

          第一種方法,使用 background-cli、 text-fill-color:

          .gradient-text-one{ 
           background-image:-webkit-linear-gradient(bottom,red,#fd8403,yellow); 
           -webkit-background-clip:text; 
           -webkit-text-fill-color:transparent; 
          }
          

          說明 :

          background: -webkit-linear-gradient(...) 為文本元素提供漸變背景。

          webkit-text-fill-color: transparent 使用透明顏色填充文本。

          webkit-background-clip: text 用文本剪輯背景,用漸變背景作為顏色填充文本。

          第二種方法,使用 mask-image:

          .gradient-text-two{
           color:red;
          }
          .gradient-text-two[data-content]::after{
           content:attr(data-content);
           display: block;
           position:absolute;
           color:yellow;
           left:0;
           top:0;
           z-index:2;
           -webkit-mask-image:-webkit-gradient(linear, 0 0, 0 bottom, from(yellow), to(rgba(0, 0, 255, 0)));
          }
          

          說明:

          mask-image 和 background-image 一樣,不僅可以取值是 圖片路徑,也可以是漸變色。

          第三種方法,使用 linearGradient、fill:

          .gradient-text-three{
           fill:url(#SVGID_1_);
           font-size:40px;
           font-weight:bolder;
          }
          <svg viewBoxs="0 0 500 300" class="svgBox">
           <defs>
           <linearGradient id="SVGID_1_" gradientUnits="userSpaceOnUse" x1="0" y1="10" x2="0" y2="50">
           <stop offset="0" style="stop-color:yellow"/>
           <stop offset="0.5" style="stop-color:#fd8403"/>
           <stop offset="1" style="stop-color:red"/>
           </linearGradient>
           </defs>
           <text text-anchor="middle" class="gradient-text-three" x="110px" y="30%">花信年華</text>
          </svg>
          

          說明:

          在SVG中,有兩種主要的漸變類型:

          線性漸變(linearGradient)

          放射性漸變(radialGradient)

          SVG中的漸變不僅可以用于填充圖形元素,還可以填充文本元素

          dom示例:

          <!DOCTYPE html>
          <html>
          <head>
           <meta charset="utf-8">
           <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
           <title>CSS3漸變字體</title>
           <link rel="stylesheet" >
           <script src="https://cdn.bootcss.com/jquery/2.1.1/jquery.min.js"></script>
           <script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
           <style type="text/css">
           *{margin:0;padding:0;}
           body,html{width:100%;height:100%;}
           .wrapper{width:80%;margin:0 auto;margin-top:30px;}
           .gradient-text{text-align: left;text-indent:30px;line-height: 50px;font-size:40px;font-weight:bolder; position: relative; }
           .gradient-text-one{ 
           background-image:-webkit-linear-gradient(bottom,red,#fd8403,yellow); 
           -webkit-background-clip:text; 
           -webkit-text-fill-color:transparent; 
           }
           .gradient-text-two{
           color:red;
           }
           .gradient-text-two[data-content]::after{
           content:attr(data-content);
           display: block;
           position:absolute;
           color:yellow;
           left:0;
           top:0;
           z-index:2;
           -webkit-mask-image:-webkit-gradient(linear, 0 0, 0 bottom, from(yellow), to(rgba(0, 0, 255, 0)));
           }
           .gradient-text-three{
           fill:url(#SVGID_1_);
           font-size:40px;
           font-weight:bolder;
           }
           </style>
          </head>
          <body>
           <section class="wrapper">
           <div class="panel panel-info">
           <div class="panel-heading">
           <h3 class="panel-title">方法1. background-clip + text-fill-color</h3>
           </div>
           <div class="panel-body">
           <h3 class="gradient-text gradient-text-one">花樣年華</h3>
           </div>
           </div>
           <div class="panel panel-warning">
           <div class="panel-heading">
           <h3 class="panel-title">方法2. mask-image</h3>
           </div>
           <div class="panel-body">
           <h3 class="gradient-text gradient-text-two" data-content="豆蔻年華">豆蔻年華</h3>
           </div>
           </div>
           <div class="panel panel-danger">
           
           <div class="panel-heading">
           <h3 class="panel-title">方法3. svg linearGradient</h3>
           </div>
           
           <div class="panel-body">
           <svg viewBoxs="0 0 500 300" class="svgBox">
           <defs>
           <linearGradient id="SVGID_1_" gradientUnits="userSpaceOnUse" x1="0" y1="10" x2="0" y2="50">
           <stop offset="0" style="stop-color:yellow"/>
           <stop offset="0.5" style="stop-color:#fd8403"/>
           <stop offset="1" style="stop-color:red"/>
           </linearGradient>
           </defs>
           <text text-anchor="middle" class="gradient-text-three" x="110px" y="30%">花信年華</text>
           </svg>
           </div>
           
           </div>
           </section>
          </body>
          </html>
          

          效果:

          這里推薦一下我的前端技術(shù)分享群:731771211,里面都是學(xué)習(xí)前端的,如果你想制作酷炫的網(wǎng)頁,想學(xué)習(xí)編程。自己整理了一份2018最全面前端學(xué)習(xí)資料,從最基礎(chǔ)的HTML+CSS+JS【炫酷特效,游戲,插件封裝,設(shè)計(jì)模式】到移動(dòng)端HTML5的項(xiàng)目實(shí)戰(zhàn)的學(xué)習(xí)資料都有整理,送給每一位前端小伙伴,有想學(xué)習(xí)web前端的,或是轉(zhuǎn)行,或是大學(xué)生,還有工作中想提升自己能力的,正在學(xué)習(xí)的小伙伴歡迎加入學(xué)習(xí)。

          SS3實(shí)現(xiàn)文本字體漸變雙色變化,實(shí)現(xiàn)顏色過渡漸變,可以用在首頁展示欄中,增強(qiáng)用戶體驗(yàn)!下面來看看效果:

          實(shí)現(xiàn)代碼非常簡(jiǎn)單:

          置知識(shí)點(diǎn)

          :root

          :root 這個(gè) CSS 偽類匹配文檔樹的根元素。對(duì)于 HTML 來說,:root 表示元素,除了優(yōu)先級(jí)更高之外,與 html 選擇器相同。

          在聲明全局 CSS 變量時(shí) :root 會(huì)很有用:

          :root {
            --main-color: hotpink;
            --pane-padding: 5px 42px;
          }


          place-items

          CSS 中的 place-items 是一個(gè)簡(jiǎn)寫屬性 ,它允許我們?cè)谙嚓P(guān)的布局(如 Grid 或 Flexbox)中可以同時(shí)沿著塊級(jí)和內(nèi)聯(lián)方向?qū)R元素 (例如:align-items 和 justify-items 屬性)。

          如果未提供第二個(gè)值,則第一個(gè)值作為第二個(gè)值的默認(rèn)值。

          也就是說,以后需要定義水平垂直居中的盒子就不需要再 justify-items: center 和 align-items: center 了,直接一行搞定,看起來更加專業(yè)。


          background-clip

          background-clip 設(shè)置元素的背景(背景圖片或顏色)是否延伸到邊框、內(nèi)邊距盒子、內(nèi)容盒子下面。

          • border-box
            背景延伸至邊框外沿(但是在邊框下層)。
          • padding-box
            背景延伸至內(nèi)邊距(padding)外沿,不會(huì)繪制到邊框處。
          • content-box
            背景被裁剪至內(nèi)容區(qū)(content box)外沿。
          • text Experimental
            背景被裁剪成文字的前景色。


          linear-gradient()

          CSS linear-gradient() 函數(shù)用于創(chuàng)建一個(gè)表示兩種或多種顏色線性漸變的圖片。

          其結(jié)果屬于 < gradient > 數(shù)據(jù)類型,是一種特別的 < image > 數(shù)據(jù)類型。


          radial-gradient()

          radial-gradient() CSS 函數(shù)創(chuàng)建了一個(gè)圖像,該圖像是由從原點(diǎn)發(fā)出的兩種或者多種顏色之間的逐步過渡組成。它的形狀可以是圓形(circle)或橢圓形(ellipse)。

          這個(gè)方法得到的是一個(gè) CSS < gradient > 數(shù)據(jù)類型的對(duì)象,是 < image > 的一種。


          實(shí)現(xiàn)效果大致如下:


          css 樣式如下:

                * {
                  box-sizing: border-box;
          
                }
                /* :root 這個(gè) CSS 偽類匹配文檔樹的根元素。對(duì)于 HTML 來說,:root 表示 <html> 元素,除了優(yōu)先級(jí)更高之外,與 html 選擇器相同。*/
                /* 在聲明全局 CSS 變量 */
                :root {
                  --color-1: #186cb8;
                  --color-2: #2a9a9f;
                  --color-3: #f1b211;
                  --color-4: #e83611;
                  --color-5: #f9002f;
                }
          
                .wrapper {
                  background: #000;
                  line-height: 1;
                  min-height: 100%;
                  display: grid;
                  place-items: center;
                  min-height: calc(100vh - 16px);
                }
          
                h1 {
                  font-family: "Exo", sans-serif;
                  font-size: 15vw;
                  font-weight: 900;
                  width: -webkit-min-content;
                  width: -moz-min-content;
                  width: min-content;
                  margin: auto;
                  text-transform: uppercase;
          
                  background: linear-gradient(
                    219deg,
                    var(--color-1) 19%,
                    transparent 19%,
                    transparent 20%,
                    var(--color-2) 20%,
                    var(--color-2) 39%,
                    transparent 39%,
          
                    transparent 40%,
                    var(--color-3) 40%,
                    var(--color-3) 59%,
                    transparent 59%,
          
                    transparent 60%,
                    var(--color-4) 60%,
                    var(--color-4) 79%,
                    transparent 79%,
          
                    transparent 80%,
                    var(--color-5) 80%
                  );
                  background-clip: text;
                  -webkit-background-clip: text;
                  color: transparent;
                }
          
                .container {
                  padding: 1.5rem;
                  text-align: center;
                  background: radial-gradient(
          
                      circle at 1.4% 1.4%,
                      var(--color-1) 0.8%,
                      transparent 0.8%
                    ),
                    radial-gradient(
          
                      circle at 5.5% 3%,
                      var(--color-2) 0.45%,
                      transparent 0.45%
                    ),
                    radial-gradient(
          
                      circle at 2.5% 3.5%,
                      var(--color-3) 0.5%,
                      transparent 0.5%
                    ),
                    radial-gradient(
          
                      circle at 4.5% 1.2%,
                      var(--color-4) 0.25%,
                      transparent 0.25%
                    ),
                    radial-gradient(
          
                      circle at 98% 98%,
                      var(--color-1) 0.8%,
                      transparent 0.8%
                    ),
                    radial-gradient(
          
                      circle at 95% 95%,
                      var(--color-2) 0.45%,
                      transparent 0.45%
                    ),
                    radial-gradient(
          
                      circle at 94.5% 97.5%,
                      var(--color-3) 0.5%,
                      transparent 0.5%
                    ),
                    radial-gradient(
          
                      circle at 98.5% 95.5%,
                      var(--color-4) 0.25%,
                      transparent 0.25%
                    );
                }
          
                @media screen and (min-width: 768px) {
                  h1 {
                    font-size: 6.5rem;
                  }
                }


          html 標(biāo)簽結(jié)構(gòu)如下:

              <divclass="wrapper">
                <divclass="container">
                  <h1>multi color text with css</h1>
                </div>
              </div>


          小結(jié)

          繪畫基礎(chǔ)圖案不難,重點(diǎn)都在于背景顏色的繪制,重點(diǎn)研究下背景代碼。


          下期給大家分享更多實(shí)戰(zhàn)中的點(diǎn)滴,如果大家對(duì)此感興趣,歡迎各位關(guān)注、留言,大家的支持就是我的動(dòng)力!


          主站蜘蛛池模板: 亚洲一区影音先锋色资源| 午夜视频久久久久一区| 国产精品合集一区二区三区| 日韩精品一区二区三区大桥未久| 一区二区三区四区在线观看视频| 人妻少妇精品视频一区二区三区 | 波多野结衣一区视频在线| 国模丽丽啪啪一区二区| 亚洲午夜电影一区二区三区| 久久精品免费一区二区| 麻豆精品一区二区综合av| 国产成人无码一区二区在线播放| 久久亚洲日韩精品一区二区三区| 亚洲制服丝袜一区二区三区| 国产福利在线观看一区二区| 国产一区三区三区| 视频在线一区二区三区| 亚洲一区二区三区无码国产| 东京热无码一区二区三区av| 人妻久久久一区二区三区| 久久一区二区免费播放| 国产AV天堂无码一区二区三区| 乱子伦一区二区三区| 日韩免费观看一区| 国产成人精品一区二区秒拍| 波多野结衣中文字幕一区| 大帝AV在线一区二区三区| 97久久精品无码一区二区| 国产成人精品无码一区二区三区| 国产精品亚洲专一区二区三区| 成人区精品一区二区不卡亚洲| 少妇激情一区二区三区视频| 久久精品亚洲一区二区| 国产AV午夜精品一区二区三区 | 亚洲一区中文字幕| 久久无码AV一区二区三区| 亚洲一区中文字幕久久| 亚洲综合av一区二区三区| 日韩久久精品一区二区三区| а天堂中文最新一区二区三区| 久久一区二区三区免费|