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 相关文章推荐
5分钟让你掌握css3阴影、倒影、渐变小技巧(小编推荐)
Aug 15 HTML / CSS
HTML5+CSS3网页加载进度条的实现,下载进度条的代码实例
Dec 30 HTML / CSS
使用css实现android系统的loading加载动画
Jul 25 HTML / CSS
HTML5 Canvas绘制文本及图片的基础教程
Mar 14 HTML / CSS
html5 input元素新特性_动力节点Java学院整理
Jul 06 HTML / CSS
HTML5 Canvas 起步(1) - 基本概念
May 12 HTML / CSS
检测浏览器是否支持html5视频的代码
Mar 28 HTML / CSS
详解Html5 监听拦截Android返回键方法
Apr 18 HTML / CSS
data:image data url 文件转为Blob上传后端的方法
Jul 16 HTML / CSS
详解如何获取localStorage最大存储大小的方法
May 21 HTML / CSS
amazeui 验证按钮扩展的实现
Aug 21 HTML / CSS
详解淘宝H5 sign加密算法
Aug 25 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数组函数序列之array_slice() - 在数组中根据条件取出一段值,并返回
2011/11/07 PHP
php 创建以UNIX时间戳命名的文件夹(示例代码)
2014/03/08 PHP
php 判断网页是否是utf8编码的方法
2014/06/06 PHP
PHP读书笔记整理_结构语句详解
2016/07/01 PHP
IE浏览器打印的页眉页脚设置解决方法
2009/12/08 Javascript
jQuery 技巧小结
2010/04/02 Javascript
iframe 异步加载技术及性能分析
2011/07/19 Javascript
JavaScript prototype 使用介绍
2013/08/29 Javascript
JSON.parse()和JSON.stringify()使用介绍
2014/06/20 Javascript
NodeJS中利用Promise来封装异步函数
2015/02/25 NodeJs
JQuery boxy插件在IE中边角图片不显示问题的解决
2015/05/20 Javascript
JQuery判断checkbox是否选中及其它复选框操作方法合集
2015/06/01 Javascript
实例解析JS布尔对象的toString()方法和valueOf()方法
2015/10/25 Javascript
jquery 重写 ajax提交并判断权限后 使用load方法报错解决方法
2016/01/19 Javascript
javascript使用 concat 方法对数组进行合并的方法
2016/09/08 Javascript
微信公众号 客服接口的开发实例详解
2016/09/28 Javascript
详解用原生JavaScript实现jQuery的某些简单功能
2016/12/19 Javascript
[02:12]2015国际邀请赛 SHOWOPEN
2015/08/05 DOTA
python根据开头和结尾字符串获取中间字符串的方法
2015/03/26 Python
python学生信息管理系统
2018/03/13 Python
Django + Uwsgi + Nginx 实现生产环境部署的方法
2018/06/20 Python
浅谈Python脚本开头及导包注释自动添加方法
2018/10/27 Python
Python分支语句与循环语句应用实例分析
2019/05/07 Python
python如何通过twisted搭建socket服务
2020/02/03 Python
python pandas.DataFrame.loc函数使用详解
2020/03/26 Python
Python使用itcaht库实现微信自动收发消息功能
2020/07/13 Python
在pycharm中使用pipenv创建虚拟环境和安装django的详细教程
2020/11/30 Python
加拿大服装和鞋类零售商:Mark’s
2021/01/04 全球购物
运动会广播稿60字
2014/01/15 职场文书
建筑施工安全生产责任书
2014/07/22 职场文书
机电专业毕业生自我鉴定2014
2014/10/04 职场文书
2015年学校综合治理工作总结
2015/07/20 职场文书
Go语言使用select{}阻塞main函数介绍
2021/04/25 Golang
Redis数据结构之链表与字典的使用
2021/05/11 Redis
element多个表单校验的实现
2021/05/27 Javascript
详解Vue router路由
2021/11/20 Vue.js