使用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 相关文章推荐
实现CSS3中的border-radius(边框圆角)示例代码
Jul 19 HTML / CSS
IE8下CSS3选择器nth-child() 不兼容问题的解决方法
Nov 16 HTML / CSS
纯css3实现宠物小鸡实例代码
Oct 08 HTML / CSS
CSS3 3D酷炫立方体变换动画的实现
Mar 26 HTML / CSS
Grid 宫格常用布局的实现
Jan 10 HTML / CSS
使用CSS3制作版头动画效果
Dec 24 HTML / CSS
HTML5 声明兼容IE的写法
May 16 HTML / CSS
使用Html5实现异步上传文件,支持跨域,带有上传进度条
Sep 17 HTML / CSS
常用的HTML5列表标签
Jun 20 HTML / CSS
html5借用repeating-linear-gradient实现一把刻度尺(ruler)
Sep 09 HTML / CSS
微信小程序canvas实现水平、垂直居中效果
Feb 05 HTML / CSS
html+css 实现简易导航栏功能
Apr 07 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
URL Rewrite的设置方法
2007/01/02 PHP
15种PHP Encoder的比较
2007/04/17 PHP
php 利用socket发送HTTP请求(GET,POST)
2015/08/24 PHP
PHP jpgraph库的配置及生成统计图表:折线图、柱状图、饼状图
2017/05/15 PHP
PHP实现腾讯与百度坐标转换
2017/08/05 PHP
PHP+Ajax实现的博客文章添加类别功能示例
2018/03/29 PHP
js兼容标准的表格变色效果
2008/06/28 Javascript
基于jQuery的自动完成插件
2011/02/03 Javascript
js select option对象小结
2013/12/20 Javascript
jquery删除ID为sNews的tr元素的内容
2014/04/10 Javascript
js动态删除div元素基本思路及实现代码
2014/05/08 Javascript
如何编写高质量JS代码
2014/12/28 Javascript
关于Jquery中的事件绑定总结
2016/10/26 Javascript
JS验证全角与半角及相互转化的介绍
2017/05/18 Javascript
Webpack优化配置缩小文件搜索范围
2017/12/25 Javascript
详解React项目的服务端渲染改造(koa2+webpack3.11)
2018/03/19 Javascript
vue移动端项目缓存问题实践记录
2018/10/29 Javascript
了解JavaScript函数中的默认参数
2019/05/30 Javascript
微信用户访问小程序的登录过程详解
2019/09/20 Javascript
[33:23]Secret vs Serenity 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
[54:17]DOTA2-DPC中国联赛定级赛 RNG vs iG BO3第二场 1月10日
2021/03/11 DOTA
Python threading多线程编程实例
2014/09/18 Python
Django框架使用内置方法实现登录功能详解
2019/06/12 Python
加热夹克:RAVEAN
2018/10/19 全球购物
New Balance澳大利亚官网:运动鞋和健身服装
2019/02/23 全球购物
营业经理岗位职责
2013/11/10 职场文书
七年级生物教学反思
2014/01/30 职场文书
兰兰过桥教学反思
2014/02/08 职场文书
小学学习雷锋活动总结
2014/07/03 职场文书
焦裕禄精神心得体会
2014/09/02 职场文书
高等学院职业生涯规划书范文
2014/09/16 职场文书
新员工考核评语
2014/12/31 职场文书
社区安置帮教工作总结2015
2015/05/20 职场文书
追讨欠款律师函
2015/05/27 职场文书
推广普通话主题班会
2015/08/17 职场文书
四年级数学教学反思
2016/02/16 职场文书