交互设计中心-72色

交互设计中心 | 用户体验 | 优化

CSS渐变文本效果

2008年6月13日 | 分类:DIV+CSS | 评论:0 | 引用:0 | | Tags:css  渐变  IE与Firefox兼容  

screen2

你是否想不用photoshop来创建一个带渐变的标题文字吗? 这里用一个简单的css技巧来向你展示如何仅仅使用css和png图片来制造这种效果. 经测试这种方法适合大多数主流浏览器.当然, IE6需要一个支持透明PNG的Hack(值得庆幸的是微软正在极力的将用户的IE6自动升级到IE7^.^, 延伸阅读:Warning: An IE7 Auto-Update Is Coming Soon)

优势

  1. 这是纯粹的css技巧,没有使用任何ja脚本或者flash, 并且它可以在大多数浏览器上正常工作(IE6需要支持透明PNG的hack)
  2. 这是完美的标题设计,你不必使用photoshop,这将大量节省你的带宽和时间.
  3. 你可以对任何网页字体使用这种效果,而且字号大小也是可变的.

他是如何工作的?

这个技巧很简单.我们只是简单的使用了1px宽的透明png覆盖在了文本上.

screen1-thumb2.gif

html

<h1>CSS Gradient Text</h1>

CSS

关键就在这里:

h1 { position: relative }
h1 span { position: absolute }

h1 {
  font: bold 330%/100% "Lucida Grande";
  position: relative;
  color: #464646;
}
h1 span {
  background: url(gradient.png) repeat-x;
  position: absolute;
  display: block;
  width: 100%;
  height: 31px;
}

就这样, 你做到了 ^_^ 点击这里查看示例.

使它能够支持IE6

下面这个hack仅仅是让IE6支持透明PNG-24格式的图片.

<!--[if lt IE 7]>
<style>
h1 span {
  background:none;
  filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=’gradient.png’, sizingMethod=’scale’);
}
</style>
<![endif]–>

jQuery生成版本

如果你不想在代码里有空的<span>标记, 那么你可以使用javascript来动态生成它. 这里是一个简单的jquery生产方法.

 

<script type="text/javascript" src="jquery.js" mce_src="jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
  //prepend span tag to H1
  $("h1").prepend("<span></span>");
});
</script>

 

更多DEMO请点击

DEMO打包下载

原文链接

Share
« 流畅的tab(选项卡)内容推荐代码区分CSS中position定位属性absolute与relative »



◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。