使用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 相关文章推荐
IE滤镜与CSS3效果(详细整理分享)
Jan 25 HTML / CSS
一款纯css3实现的颜色渐变按钮的代码教程
Nov 12 HTML / CSS
css3 中的新特性加强记忆详解
Apr 16 HTML / CSS
详解CSS3弹性伸缩盒
Sep 21 HTML / CSS
HTML5实现视频直播功能思路详解
Nov 16 HTML / CSS
Html5之svg可缩放矢量图形_动力节点Java学院整理
Jul 17 HTML / CSS
一波HTML5 Canvas基础绘图实例代码集合
Feb 28 HTML / CSS
HTML5 Canvas的常用线条属性值总结
Mar 17 HTML / CSS
AmazeUI中各种的导航式菜单与解决方法
Aug 19 HTML / CSS
用position:sticky完美解决小程序吸顶问题的实现方法
Apr 24 HTML / CSS
基于HTML十秒做出淘宝页面
Oct 24 HTML / CSS
css中:last-child不生效的解决方法
Aug 05 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
DC的38部超级英雄动画电影
2020/03/03 欧美动漫
PHP __autoload()方法真的影响性能吗?
2012/03/30 PHP
YII实现分页的方法
2014/07/09 PHP
php实现把url转换迅雷thunder资源下载地址的方法
2014/11/07 PHP
php arsort 数组降序排序详细介绍
2016/11/17 PHP
JavaScript设置FieldSet展开与收缩
2009/05/15 Javascript
解析使用js判断只能输入数字、字母等验证的方法(总结)
2013/05/14 Javascript
jquery 滚动条事件简单实例
2013/07/12 Javascript
js单例模式详解实例
2013/11/21 Javascript
使用jquery实现放大镜效果
2014/09/02 Javascript
Vue2.0使用过程常见的一些问题总结学习
2017/04/10 Javascript
vue-router 实现导航守卫(路由卫士)的实例代码
2018/09/02 Javascript
微信小程序实现类似微信点击语音播放效果
2020/03/30 Javascript
微信小程序分包加载代码实现方法详解
2019/09/23 Javascript
javascript实现异形滚动轮播
2019/11/28 Javascript
详解JavaScript中的链式调用
2020/11/27 Javascript
[04:52]DOTA2亚洲邀请赛附加赛 TOP10精彩集锦
2015/01/29 DOTA
python通过urllib2获取带有中文参数url内容的方法
2015/03/13 Python
Python中operator模块的操作符使用示例总结
2016/06/28 Python
Django如何配置mysql数据库
2018/05/04 Python
利用python和百度地图API实现数据地图标注的方法
2019/05/13 Python
Python 一键制作微信好友图片墙的方法
2019/05/16 Python
Pandas的read_csv函数参数分析详解
2019/07/02 Python
python绘制直方图和密度图的实例
2019/07/08 Python
python 常见的排序算法实现汇总
2020/08/21 Python
python中字符串的编码与解码详析
2020/12/03 Python
python中实现词云图的示例
2020/12/19 Python
全球游戏Keys和卡片市场:GamesDeal
2018/03/28 全球购物
求职推荐信范文
2013/12/01 职场文书
小学网上祭英烈活动总结
2014/07/05 职场文书
2014年社区居委会主任重阳节讲话稿
2014/09/25 职场文书
大学生村官个人对照检查材料(群众路线)
2014/09/26 职场文书
运动会广播稿50字-100字
2014/10/11 职场文书
优秀共产党员事迹材料
2014/12/18 职场文书
团员自我评价范文
2015/03/10 职场文书
微信小程序实现拍照和相册选取图片
2021/05/09 Javascript