使用CSS3的背景渐变Text Gradient 创建文字颜色渐变


Posted in HTML / CSS onAugust 19, 2014

考虑一下,如何在网页中达到类似以下文字渐变的效果?

传统的实现中,是用一副透明渐变的图片覆盖在文字上。具体实现方式可参考 http://www.qianduan.net/css-gradient-text-effect.html 。这种方式优点是图片可控,所以可实现很复杂的渐变效果,但是缺点是图片渐变色必须与背景色一致,同时损失了鼠标点击、文字选择等事件。

改进的方法可以使用 CSS3 的背景渐变 -webkit-gradient ,用一个背景渐变的 DIV 代替图片。下面是实现效果示例,相比以上方案优点是不使用图片,减小请求量和流量,但是对于以上缺点,仍然无法解决。

有没有完美的解决方案呢?

以下介绍使用 -webkit-mask 遮罩的方案来实现文字渐变,完全避免了以上方案的不足。下面是实现的完美效果图:

现在让我们开始 CSS3 Text Gradient 之旅。

1、构建 HTML 内容和基本样式

我们使用一个 H1 标签包裹一个 A 标签:

<h1><a href= "#" mce_href= "#" >Jiangyujie</a></h1>

<h1><a href="#" mce_href="#">Jiangyujie</a></h1>

样式定义如下,我们使用 text-shadow 为文字添加阴影:

复制代码
代码如下:

h1 {
font-family: Segoe UI, Verdana, sans-serif;
font-size: 100px;
line-height: 100px;
text-shadow: -3px 0 4px #006;
}
h1 a:link,
h1 a:visited,
h1 a:hover,
h1 a:active {
color: #d12;
text-decoration: none;
}
复制代码
代码如下:

h1 {
font-family: Segoe UI, Verdana, sans-serif;
font-size: 100px;
line-height: 100px;
text-shadow: -3px 0 4px #006;
}
h1 a:link,
h1 a:visited,
h1 a:hover,
h1 a:active {
color: #d12;
text-decoration: none;
}

基本效果如下:

2、添加渐变效果

我们通过 CSS3 的 mask 属性为文字添加线性渐变。和 background 的渐变相比,可以理解为 background是在文字后面,而 mask 是叠加在文字上面的。 Mask 可以设置为普通颜色、线性渐变、径向渐变或者图片。

代码如下:

复制代码
代码如下:

h1 a:link,
h1 a:visited,
h1 a:hover,
h1 a:active {
color: #d12;
text-decoration: none;
-webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0,0,0,1)), to(rgba(0,0,0,0)));
}
复制代码
代码如下:

h1 a:link,
h1 a:visited,
h1 a:hover,
h1 a:active {
color: #d12;
text-decoration: none;
-webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0,0,0,1)), to(rgba(0,0,0,0)));
}

效果如下所示:

3、渐变为另外一种颜色

因为 -webkit-gradient 实际上是按照图片的方式进行处理的,所以我们不能通过设置文字颜色为渐变来实现文字颜色渐变为另外一种颜色的效果(不信的话你可以试试)。

所以我们要构造一个伪元素,内容和我们的文本一样,使用伪元素的原因是避免再添加一个同样内容的标签造成代码冗余:

复制代码
代码如下:

h1:after {
content: "Jiangyujie" ;
color: #000;
text-shadow: 3px 3px 1px #600;
}
复制代码
代码如下:

h1:after {
content: "Jiangyujie";
color: #000;
text-shadow: 3px 3px 1px #600;
}

然后我们通过position属性将两个文本重叠在一起:
复制代码
代码如下:

h1 {
position: relative;
font-family: Segoe, Verdana, sans-serif;
font-size: 100px;
line-height: 100px;
text-shadow: -3px 0 4px #006;
}
h1 a:link,
h1 a:visited,
h1 a:hover,
h1 a:active {
position: absolute;
text-decoration: none;
top: 0;
z-index: 2;
color: #d12;
-webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0,0,0,1)), to(rgba(0,0,0,0)));
}
复制代码
代码如下:

h1 {
position: relative;
font-family: Segoe, Verdana, sans-serif;
font-size: 100px;
line-height: 100px;
text-shadow: -3px 0 4px #006;
}
h1 a:link,
h1 a:visited,
h1 a:hover,
h1 a:active {
position: absolute;
text-decoration: none;
top: 0;
z-index: 2;
color: #d12;
-webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0,0,0,1)), to(rgba(0,0,0,0)));
}

效果如下图所示:

4、添加背景

这种实现方式的优势是我们可以自定义背景,完全不受渐变颜色的影响。例如我们可以为文字添加一副背景,效果如下:

很棒的效果,不是吗:)

5、其他

CSS3 mask 的详细信息可以参考 Webkit.org 的 文章 。

HTML / CSS 相关文章推荐
网页布局中CSS样式无效的十个重要原因详解
Aug 10 HTML / CSS
css3 给背景设置渐变色的方法
Sep 12 HTML / CSS
css3学习系列之移动属性详解
Jul 04 HTML / CSS
CSS3实现多样的边框效果
May 04 HTML / CSS
Html5移动端弹幕动画实现示例代码
Aug 27 HTML / CSS
利用HTML5 Canvas制作一个简单的打飞机游戏
May 11 HTML / CSS
详解使用HTML5 Canvas创建动态粒子网格动画
Dec 14 HTML / CSS
HTML5实现文件断点续传的方法
Jan 04 HTML / CSS
HTML5响应式(自适应)网页设计的实现
Nov 17 HTML / CSS
关于canvas绘制模糊问题的解决方法
Sep 24 HTML / CSS
CSS3实现列表无限滚动/轮播效果
Jun 23 HTML / CSS
详解CSS3浏览器兼容
Dec 24 HTML / CSS
css3中新增的样式使用示例附效果图
Aug 19 #HTML / CSS
css3 position fixed固定居中问题解决方案
Aug 19 #HTML / CSS
CSS3实现多背景展示效果通过CSS3定位多张背景
Aug 10 #HTML / CSS
CSS3实现圆角、阴影、透明效果并兼容各大浏览器
Aug 08 #HTML / CSS
CSS3制作文字半透明倒影效果的两种实现方式
Aug 08 #HTML / CSS
CSS3 transform的skew属性值图文详解
Jul 21 #HTML / CSS
目前不被任何主流浏览器支持的CSS3属性汇总
Jul 21 #HTML / CSS
You might like
用php+mysql一个名片库程序
2006/10/09 PHP
PHP学习笔记 用户注册模块用户类以及验证码类
2011/09/20 PHP
基于PHP对XML的操作详解
2013/06/07 PHP
一组PHP加密解密函数分享
2014/06/05 PHP
解决thinkphp5未定义变量会抛出异常,页面错误,请稍后再试的问题
2019/10/16 PHP
JavaScript 比较时间大小的代码
2010/04/24 Javascript
javascrpt绑定事件之匿名函数无法解除绑定问题
2012/12/06 Javascript
常用的几段javascript代码分享
2014/03/25 Javascript
JavaScript限定图片显示大小的方法
2015/03/11 Javascript
jquery+html5制作超酷的圆盘时钟表
2015/04/14 Javascript
原生js和jquery实现图片轮播特效
2015/04/23 Javascript
jquery中的工具使用方法$.isFunction, $.isArray(), $.isWindow()
2015/08/09 Javascript
WEB前端开发都应知道的jquery小技巧及jquery三个简写
2015/11/15 Javascript
浅谈JavaScript的自动垃圾收集机制
2016/12/15 Javascript
纯JS实现出生日期[年月日]下拉菜单效果
2018/06/01 Javascript
vue中动态设置meta标签和title标签的方法
2018/07/11 Javascript
微信小程序在地图选择地址并返回经纬度简单示例
2018/12/03 Javascript
layui清除radio的选中状态实例
2019/11/14 Javascript
在vscode 中设置 vue模板内容的方法
2020/09/02 Javascript
利用Python学习RabbitMQ消息队列
2015/11/30 Python
python3.6使用urllib完成下载的实例
2018/12/19 Python
python matplotlib折线图样式实现过程
2019/11/04 Python
解决python gdal投影坐标系转换的问题
2020/01/17 Python
Python任务调度模块APScheduler使用
2020/04/15 Python
Pycharm如何导入python文件及解决报错问题
2020/05/10 Python
使用postMessage让 iframe自适应高度的方法示例
2019/10/08 HTML / CSS
会计学专业学生的求职信范文
2014/01/27 职场文书
护理专科自荐书范文
2014/02/18 职场文书
检讨书范文2000字
2015/01/28 职场文书
教师节联欢会主持词
2015/07/04 职场文书
煤矿隐患排查制度
2015/08/05 职场文书
vue+elementui 实现新增和修改共用一个弹框的完整代码
2021/06/08 Vue.js
Mysql排序的特性详情
2021/11/01 MySQL
Python利用capstone实现反汇编
2022/04/06 Python
Java8利用Stream对列表进行去除重复的方法详解
2022/04/14 Java/Android
Python 图片添加美颜效果
2022/04/28 Python