整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

css文字颜色渐变的3种实现

者:IT智云编程

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

在web前端开发过程中,UI设计师经常会设计一些带渐变文字的设计图,在以前我们只能用png的图片来代替文字,今天可以实现使用纯CSS实现渐变文字了。下面就介绍3中实现方式供大家参考!

基础样式:

.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" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css">
 <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>

效果:

这里推荐一下我的前端技术分享群:731771211,里面都是学习前端的,如果你想制作酷炫的网页,想学习编程。自己整理了一份2018最全面前端学习资料,从最基础的HTML+CSS+JS【炫酷特效,游戏,插件封装,设计模式】到移动端HTML5的项目实战的学习资料都有整理,送给每一位前端小伙伴,有想学习web前端的,或是转行,或是大学生,还有工作中想提升自己能力的,正在学习的小伙伴欢迎加入学习。

SS3实现文本字体渐变双色变化,实现颜色过渡渐变,可以用在首页展示栏中,增强用户体验!下面来看看效果:

实现代码非常简单:

置知识点

:root

:root 这个 CSS 伪类匹配文档树的根元素。对于 HTML 来说,:root 表示元素,除了优先级更高之外,与 html 选择器相同。

在声明全局 CSS 变量时 :root 会很有用:

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


place-items

CSS 中的 place-items 是一个简写属性 ,它允许我们在相关的布局(如 Grid 或 Flexbox)中可以同时沿着块级和内联方向对齐元素 (例如:align-items 和 justify-items 属性)。

如果未提供第二个值,则第一个值作为第二个值的默认值。

也就是说,以后需要定义水平垂直居中的盒子就不需要再 justify-items: center 和 align-items: center 了,直接一行搞定,看起来更加专业。


background-clip

background-clip 设置元素的背景(背景图片或颜色)是否延伸到边框、内边距盒子、内容盒子下面。

  • border-box
    背景延伸至边框外沿(但是在边框下层)。
  • padding-box
    背景延伸至内边距(padding)外沿,不会绘制到边框处。
  • content-box
    背景被裁剪至内容区(content box)外沿。
  • text Experimental
    背景被裁剪成文字的前景色。


linear-gradient()

CSS linear-gradient() 函数用于创建一个表示两种或多种颜色线性渐变的图片。

其结果属于 < gradient > 数据类型,是一种特别的 < image > 数据类型。


radial-gradient()

radial-gradient() CSS 函数创建了一个图像,该图像是由从原点发出的两种或者多种颜色之间的逐步过渡组成。它的形状可以是圆形(circle)或椭圆形(ellipse)。

这个方法得到的是一个 CSS < gradient > 数据类型的对象,是 < image > 的一种。


实现效果大致如下:


css 样式如下:

      * {
        box-sizing: border-box;

      }
      /* :root 这个 CSS 伪类匹配文档树的根元素。对于 HTML 来说,:root 表示 <html> 元素,除了优先级更高之外,与 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 标签结构如下:

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


小结

绘画基础图案不难,重点都在于背景颜色的绘制,重点研究下背景代码。


下期给大家分享更多实战中的点滴,如果大家对此感兴趣,欢迎各位关注、留言,大家的支持就是我的动力!