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轻松实现清新 Loading 效果的简单实例
Jun 06 HTML / CSS
css3图片边框border-image的用法
Jun 30 HTML / CSS
CSS3 Backgrounds属性相关介绍
May 11 HTML / CSS
CSS3的resize属性使用初探
Sep 27 HTML / CSS
CSS3 display知识详解
Nov 25 HTML / CSS
关于css兼容性问题及一些常见问题汇总
May 03 HTML / CSS
Css3新特性应用之形状总结
Dec 08 HTML / CSS
HTML 5 input placeholder 属性如何完美兼任ie
May 12 HTML / CSS
canvas绘图按照contain或者cover方式适配并居中显示
Feb 18 HTML / CSS
3种方式实现瀑布流布局小结
Sep 05 HTML / CSS
Canvas波浪花环的示例代码
Aug 21 HTML / CSS
CSS3 Tab动画实例之背景切换动态效果
Aug 23 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
php microtime获取浮点的时间戳
2010/02/21 PHP
codeigniter教程之多文件上传使用示例
2014/02/11 PHP
PHP发送短信代码分享
2015/08/11 PHP
PHP数学运算函数大汇总(经典值得收藏)
2016/04/01 PHP
使用Yii2实现主从数据库设置
2016/11/20 PHP
PHP实现截取中文字符串不出现?号的解决方法
2016/12/29 PHP
用AJAX返回HTML片段中的JavaScript脚本
2010/01/04 Javascript
ComboBox 和 DateField 在IE下消失的解决方法
2013/08/30 Javascript
JavaScript中的单引号和双引号报错的解决方法
2014/09/01 Javascript
Jquery遍历Json数据的方法
2015/04/20 Javascript
jQuery实现页面内锚点平滑跳转特效的方法总结
2015/05/11 Javascript
两款JS脚本判断手机浏览器类型跳转WAP手机网站
2015/10/16 Javascript
Canvas放置反弹效果随机图形(实例)
2017/08/17 Javascript
JQuery元素快速查找与操作
2018/04/22 jQuery
JavaScript生成指定范围随机数和随机序列的方法
2018/05/05 Javascript
Vue-router 中hash模式和history模式的区别
2018/07/24 Javascript
react 中父组件与子组件双向绑定问题
2019/05/20 Javascript
JavaScript如何借用构造函数继承
2019/11/06 Javascript
基于vue-cli3创建libs库的实现方法
2019/12/04 Javascript
vue项目中使用bpmn-自定义platter的示例代码
2020/05/11 Javascript
vue图片裁剪插件vue-cropper使用方法详解
2020/12/16 Vue.js
[49:31]DOTA2-DPC中国联赛 正赛 Elephant vs LBZS BO3 第二场 1月29日
2021/03/11 DOTA
python排序方法实例分析
2015/04/30 Python
Python虚拟环境项目实例
2017/11/20 Python
python暴力解压rar加密文件过程详解
2019/07/05 Python
在python中创建指定大小的多维数组方式
2019/11/28 Python
商务日语专业自荐信
2014/04/17 职场文书
2014镇党委班子对照检查材料思想汇报
2014/09/23 职场文书
会计出纳岗位职责
2015/03/31 职场文书
困难补助申请报告
2015/05/19 职场文书
歌咏比赛主持词
2015/06/29 职场文书
董事会决议范本
2015/07/01 职场文书
同事欢送会致辞
2015/07/31 职场文书
ORACLE数据库对long类型字段进行模糊匹配的解决思路
2021/04/07 Oracle
如何搭建 MySQL 高可用高性能集群
2021/06/21 MySQL
SpringBoot快速入门详解
2021/07/21 Java/Android