CSS3下的渐变文字效果实现示例


Posted in HTML / CSS onMarch 02, 2018

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

如果您手头上的浏览器是Chrome或是Safari,则您可以在demo页面中看到类似下面的效果:

CSS3下的渐变文字效果实现示例

方法一下的文字渐变效果

相应的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)));
}

从CSS代码可以看出,效果的实现除了“content内容生成技术”以外,主要是使用了mask-image属性,内容则是“webkit核心浏览器下的渐变”了。

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

如果您手头上的浏览器是Chrome或是Safari,则您可以在demo页面中看到类似下面的效果:

CSS3下的渐变文字效果实现示例

方法二下的文字渐变效果

此处实现相对上面要简单些,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-color与mask-image属性貌似就webkit核心的浏览器支持,所以两个demo页面只能在Chrome浏览器或是Safari浏览器下才能看到渐变效果。Firefox浏览器下纯色,IE下就更不用说了。

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3实现的文本3D效果附图
Sep 03 HTML / CSS
浅析与CSS3的loading动画加载相关的transition优化
May 18 HTML / CSS
css sprite简单实例
May 23 HTML / CSS
CSS3中设置3D变形的transform-style属性详解
May 23 HTML / CSS
详解CSS3原生支持div铺满浏览器的方法
Aug 30 HTML / CSS
css3 transform导致子元素固定定位变成绝对定位的方法
Mar 06 HTML / CSS
解决img标签上下出现间隙的方法
Dec 14 HTML / CSS
关于HTML5的22个初级技巧(图文教程)
Jun 21 HTML / CSS
为你的html5网页添加音效示例
Apr 03 HTML / CSS
移动端开发HTML5页面点击按钮后出现闪烁或黑色背景的解决办法
Sep 19 HTML / CSS
Html5新增了哪些功能
Apr 16 HTML / CSS
在CSS中使用when/else的方法
Jan 18 HTML / CSS
CSS3 @keyframes简单动画实现
Feb 24 #HTML / CSS
css3 实现圆形旋转倒计时
Feb 24 #HTML / CSS
css3 仿写阿里云水纹效果的示例代码
Feb 10 #HTML / CSS
纯css3使用vw和vh实现自适应的方法
Feb 09 #HTML / CSS
如何用css3实现switch组件开关的方法
Feb 09 #HTML / CSS
结合 CSS3 transition transform 实现简单的跑马灯效果的示例
Feb 07 #HTML / CSS
css3 clip实现圆环进度条的示例代码
Feb 07 #HTML / CSS
You might like
Symfony2实现从数据库获取数据的方法小结
2016/03/18 PHP
php 5.4 全新的代码复用Trait详解
2017/01/05 PHP
php 使用ActiveMQ发送消息,与处理消息操作示例
2020/02/23 PHP
RR vs IO BO3 第一场2.13
2021/03/10 DOTA
Jquery加载时从后台读取数据绑定到dropdownList实例
2013/06/09 Javascript
js下拉菜单语言选项简单实现
2013/09/23 Javascript
JS扩展方法实例分析
2015/04/15 Javascript
JS实现的Select三级下拉菜单代码
2015/08/20 Javascript
js生成随机数(指定范围)的实例代码
2016/07/10 Javascript
基于JavaScript实现跳转提示页面
2016/09/24 Javascript
Nodejs实现爬虫抓取数据实例解析
2018/07/05 NodeJs
给localStorage设置一个过期时间的方法分享
2018/11/06 Javascript
详解Vue 匿名、具名和作用域插槽的使用方法
2019/04/22 Javascript
vue中获取滚动table的可视页面宽度调整表头与列对齐(每列宽度不都相同)
2019/08/17 Javascript
vue2.0 获取从http接口中获取数据,组件开发,路由配置方式
2019/11/04 Javascript
python实现媒体播放器功能
2018/02/11 Python
Python中出现IndentationError:unindent does not match any outer indentation level错误的解决方法
2020/04/18 Python
使用python itchat包爬取微信好友头像形成矩形头像集的方法
2019/02/21 Python
opencv导入头文件时报错#include的解决方法
2019/07/31 Python
Python 字符串、列表、元组的截取与切片操作示例
2019/09/17 Python
python+Django实现防止SQL注入的办法
2019/10/31 Python
python模拟实现斗地主发牌
2020/01/07 Python
Python join()函数原理及使用方法
2020/11/14 Python
使用Django的JsonResponse返回数据的实现
2021/01/15 Python
青春无悔演讲稿
2014/05/08 职场文书
找工作求职信
2014/07/07 职场文书
学校运动会报道稿
2014/09/23 职场文书
流动人口婚育证明范本
2014/09/26 职场文书
政风行风整改方案
2014/10/25 职场文书
2014年新教师工作总结
2014/11/08 职场文书
2014年项目工作总结
2014/11/24 职场文书
公司副总经理岗位职责
2015/04/08 职场文书
导游词之韩国济州岛
2019/10/28 职场文书
写一个Python脚本下载哔哩哔哩舞蹈区的所有视频
2021/05/31 Python
div与span之间的区别与使用介绍
2021/12/06 HTML / CSS
【海涛DOTA解说】EVE女子战队独家录像加ZSMJ神牛两连发
2022/04/01 DOTA