当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > CSS教程:可扩展圆角标签的实现方法

CSS样式表
50个强大璀璨的CSS3/JS技术运用实例
table建站,XHTML建站和DIV建站的不同
根据W3C的CSS3草案翻译的CSS3参考手册
RoundedCornr:生成圆角图片的好用的简单工具
CSS教程:彻底了解haslayout
CSS3的简单又实用的3个属性
CSS教程:-moz-inline-box和-moz-inline-stack
css3阴影属性box-shadow注意事项
css3文本阴影属性text-shadow说明
CSS3的border-radius(圆角)
border边框属性在浏览器中的渲染方式
CSS属性:text-shadow,box-shadow,border-radius
再论清除浮动的空DIV方法
YUI网页布局:自适应宽度的输入框
学习web标准:Web标准中的特殊字符
优化浏览器渲染:将样式表放在页面顶部
优化浏览器渲染:指定图片尺寸
优化浏览器渲染:避免CSS expressions
CSS3 Please:在线生成跨浏览器的CSS3代码
CSS实例教程:制作漂亮的网页表单

CSS样式表 中的 CSS教程:可扩展圆角标签的实现方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-09   浏览: 143 ::
收藏到网摘: n/a

 在制作网页的时候,很流行使用标签的方式进行分类显示,圆角标签具有样式美观、表现方式形象的优点,一般我们都会将圆角标签的背景制作成一张图片,这样做的不足之处是如果标签文字字数变化(如图1),固定的背景图片不能随之进行扩展。这样我们就需要制作很多张不同宽度的背景图片,很不方便。下面介绍两种制作可扩展圆角标签的方法。

图一

图1
      描边圆角标签

  如图1所示,圆角标签的边缘和背景颜色不同,首先我们需要在photoshop中制作一张背景图片(如图2),图片宽度要比可能出现的文字长度稍宽,高度至少等于标签实际高度,边缘设置为描边颜色,内部为透明,但是圆角以外的区域不能设置为透明,应该用页面背景颜色填充,这里使用的是白色,我们将其命名为tab_bg.gif。

图2

图2
      代码如下:

以下是引用片段:
<style type="text/css">
a.tab{ float:left; margin:10px; padding-right:10px; background:#4B90C6 url(tab_bg.gif) right top no-repeat; font:bold 14px/30px 'Verdana'; color:#FFF;}
a.tab span{ padding-left:10px; background:url(tab_bg.gif) no-repeat; display:block;}
</style>

<body bgcolor="#FFFFFF">
<a href="#" class="tab"><span>首页</span></a>
<a href="#" class="tab"><span>个人资料</span></a>
<a href="#" class="tab"><span>留言本</span></a>
</body>
 
  代码说明:

  1.实现思路是给<a>标签设置标签右侧背景,给<span>标签设置标签左侧背景来实现圆角标签的扩展;
  2.这种方法只需要下载一张背景图片,解决了标签两侧背景显示不同步的问题,但是如果标签内的字数超过了背景图片的宽度,就会出现问题(如图3),所以在制作背景图片的时候,图片宽度应尽可能的考虑到最长的字符宽度。

图3

图3
 
      单色圆角标签
  上面一种情况由于需要实现描边效果,所以文字只能在背景宽度之内扩展,有一定的局限性。如果是单色的圆角标签就可以实现完全扩展(如图4)。

图4


图4
  将第一次用到的背景图片左侧和右侧分别切成背景图片(如图5),命名为tab_left.gif和tab_right.gif。

图5


图5

      代码如下:

以下是引用片段:
<style type="text/css">
a.tab{ float:left; margin:10px; padding-right:10px; background:#033EA5 url(tab_right.gif) right top no-repeat; font:bold 14px/30px 'Verdana'; color:#FFF;}
a.tab span{ padding-left:10px; background:url(tab_left.gif) no-repeat; display:block;}
</style>

<body bgcolor="#FFFFFF">
<a href="#" class="tab"><span>首页</span></a>
<a href="#" class="tab"><span>个人资料</span></a>
<a href="#" class="tab"><span>留言本</span></a>
</body>
 

      代码说明:
  1.对<a>和<span>使用了不同的背景,并将链接背景色设置为描边颜色,达到单色标签效果;
  2.此种方法可以达到任意扩展的效果。