• CSS3下的渐变文字效果实现


    作者:张鑫旭

    一、方法一:借助mask-image属性

    相应的HTML代码如下:

    <h2 class="text-gradient" data-text="天赐美妞">天赐美妞</h2> 

    与HTML相对应的CSS代码如下:

    .text-gradient {  
        display: inline-block;
        font-family: '微软雅黑';
        font-size: 10em;
        position: relative; 
    }  
      
    .text-gradient[data-text]::after {  
        content: attr(data-text);  
        color: green;  
        position: absolute;  
        left: 0;  
        z-index: 2;
        -webkit-mask-image: -webkit-gradient(linear, 0 0, 0 bottom, from(#ff0000), to(rgba(0, 0, 255, 0)));
    }

    二、方法二:background-clip + text-fill-color下的实现

    此处实现相对上面要简单些,HTML代码如下:

    <h2 class="text-gradient">天赐美妞</h2>

    与HTML相对应的CSS代码如下:

    .text-gradient {  
        display: inline-block;
        color: green;
        font-size: 10em;
        font-family: '微软雅黑';
        background-image: -webkit-gradient(linear, 0 0, 0 bottom, from(rgba(0, 128, 0, 1)), to(rgba(51, 51, 51, 1)));
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }; 

    CSS代码中关键有用的其实就是最后三行:

    background-image: -webkit-gradient(linear, 0 0, 0 bottom, from(rgba(0, 128, 0, 1)), to(rgba(51, 51, 51, 1)));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    

    此方法虽然使用的CSS属性相对多些,但是结构简单,易于控制,颜色的选取与控制也更精确,理解上也更容易理解。我个人是推荐使用方法二的。

    三、结语

    由于目前text-fill-colormask-image属性貌似就webkit核心的浏览器支持,所以两个demo页面只能在Chrome浏览器或是Safari浏览器下才能看到渐变效果。Firefox浏览器下纯色,IE下就更不用说了。

    但是,文字渐变本身就是装饰性的功能,所以,本着渐进增强的原则,我们在实际项目中其实是可以大胆使用的。在不影响原来功能基础上,几行CSS代码,让占有率愈来愈高的Chrome浏览器下有更好的视觉体验效果,何乐而不为呢?

  • 相关阅读:
    Linux常用命令大全
    C# 多线程、控制线程数提高循环输出效率
    【Redis笔记(四)】 Redis数据结构
    Redis 详解 (一) StackExchange.Redis Client
    C#中的线程(一)入门
    C#多线程
    StackExchange.Redis帮助类解决方案RedisRepository封装(散列Hash类型数据操作)
    【转】C#中使用Redis学习二 在.NET4.5中使用redis hash操作
    使用MongoDB.NET 2.2.4驱动版本对 Mongodb3.3数据库中GridFS增删改查
    .Net-Mongodb学习大全网址
  • 原文地址:https://www.cnblogs.com/zyx-blog/p/9182776.html
Copyright © 2020-2023  润新知