日期:2014-05-17  浏览次数:20806 次

使用CSS3创建文字颜色渐变(CSS3 Text Gradient)

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

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

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

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

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

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

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

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

view plaincopy to clipboardprint?
  1. <h1><a?href= "#" ?mce_href= "#" >Jiangyujie</a></h1>??

?

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

view plaincopy to clipboardprint?
  1. h1?{??
  2. ????font-family:?Segoe?UI,?Verdana,?sans-serif;??
  3. ????font-size:?100px;??
  4. ????line-height:?100px;??
  5. ????text-shadow:?-3px?0?4px?#006;??
  6. }??
  7. h1?a:link,??
  8. h1?a:visited,??
  9. h1?a:hover,??
  10. h1?a:active?{??
  11. ????color:?#d12;??
  12. ????text-decoration:?none;??
  13. }??

?

?? ? ? ??基本效果如下:

?? ? ? ??2、? 添加渐变效果:

?? ? ? ??我们通过 CSS3 mask 属性为文字添加线性渐变。和 background 的渐变相比,可以理解为 background 是在文字后面,而 mask 是叠加在文字上面的。<