巧妙利用CSS自定义网页下划线样式

css|网页

  CSS为网页设计者们提供了丰富而灵活的页面元素表现形式的控制手段。但是,或许你可能注意到了,对于下划线,CSS提供的可选操作却不是很多。一般情况下,人们看到的下划线基本上都是横直线,缺少生气和灵动。不过,路并不是死的,通过一些绝妙的改造,我们还是可以做出富有创意的下划线来使页面更为美观。

这是一个自定义下划线的例子:自定义的下划线 。是不是很酷呢?除了能让你的网页呈现出一个与众不同的风格之外,它还能对于文档中不同的文字类型给与不同的视觉外观,起到提醒或者着重的作用。

下面我们就来一起学习如何自定义与众不同的下划线。

首先,我们得先准备一幅作为下划线的图片。你可以利用先成的,也可以自己动手绘制。需要提醒注意的是,你所准备的图片应该适合水平方向上的重复,最好还能使透明的GIF格式,这样能够确保背景不被遮挡。

另外,如果你所准备的下划线图片在高度(粗细)上占用比较多的像素,那么,应当增加该行文本和下行文本之间的行距(line-height)空间,可以这么设定:

p { line-height: 1.5; }

接下来要做的事情是取消原来默认的下划线,这样我们才能把自定义的下划线应用到指定文本,使用如下的CSS设定(它的含义是让超链接文字没有任何修饰):

a { text-decoration: none; }

好了,现在可以来创建自定义的下划线了,这里,我们用准备的图片设定为超链接元素的背景图片,如下:

a { background-image: url(underline.gif); }

当然,文字的长度未必和原图的长度相等,这就需要考虑图片重复的问题,也就是说,应当把重复限定在水平方向的X轴上,可以如下设定:

a { background-repeat: repeat-x; }

还有个必须考虑的问题,就是字的大小改变怎么办?要让下划线的图片始终显示在超链接文字的下方,而不必理会文字大小的话,我们应当使用CSS中的背景位置(background-position)属性来定位图片位于超链接元素色底部。而对于如箭头这样的下划线图片,还得考虑超链接的文本边缘和图片边对齐。 下面的这个例子将下划线背景图片的位置限定在右下角:

a { background-position: 100% 100%; }

如何控制自定义的下划线图片和文字之间的空白呢?这个可以通过增加填充(padding)来做到。下划线图片相对于超链接文本基线(baseline)的确切位置以来与所用的字的大小。建议你一开始将底部填充(bottom-padding)的大小设定同下划线图片的高度相等,然后再慢慢调整到合适位置(下面这个CSS设定超链接的底部填充为4像素):

a { padding-bottom: 4px; }

因为下划线的图片被定位在超链接元素的底部,所以需要确保所用的超链接文本没有跨行,否则,只有处在最下面的超链接文本会出现自定义的下划线了。怎么解决呢,那就是阻止超链接文本跨行产生,可以通过CSS的white-space属性来完成:

a { white-space: nowrap; }

好了,把上面提到的这些超链接标记的CSS设定合并起来,结果如下:

a {
text-decoration: none;
background: url(underline.gif) repeat-x 100% 100%;
padding-bottom: 4px;
white-space: nowrap;
}

还记得有些超链接文本没有下划线,但是当鼠标移到它的上面的时候,下划线就浮现出来的情况么?自定义的下划线也可以做到这个效果,那就在:hover上设定超链接背景,而不是在超链接标记a上设定,如下:

a {
text-decoration: none;
padding-bottom: 4px;
white-space: nowrap;
}

a:hover {
background: url(underline.gif) repeat-x 100% 100%;
}

怎么样,是不是很简单呢?在来看看一些例子和它们对应的CSS设定:

静态下划线

a#example3a {
text-decoration: none;
background: url('diagonal.gif') repeat-x 100% 100%;
white-space: nowrap;
padding-bottom: 2px
}
 

浮动效果下划线

a#example3b {
text-decoration: none;
white-space: nowrap;
padding-bottom: 2px;
}

a#example3b:hover {
background: url('diagonal.gif') repeat-x 100% 100%;
}
 

静态下划线

a#example4a {
text-decoration: none;
background: url('flower.gif') repeat-x 100% 100%;
white-space: nowrap;
padding-bottom: 10px
}

浮动花朵效果下划线

a#example4b {
text-decoration: none;
white-space: nowrap;
padding-bottom: 10px;
}

a#example4b:hover {
background: url('flower.gif') repeat-x 100% 100%;
}

静态箭头下划线

a#example1a {
text-decoration: none;
background: url('arrow.gif') repeat-x 100% 100%;
white-space: nowrap;
padding-bottom: 5px
}
 

浮动动画箭头下划线 (这里箭头会出现滚动,不过这一滚动图片的效果只在部分浏览器中看得到)

a#example2b {
text-decoration: none;
white-space: nowrap;
padding-bottom: 5px;
}

a#example2b:hover {
background: url('animarrow.gif') repeat-x 100% 100%;
}

时间: 2024-12-22 15:51:19

巧妙利用CSS自定义网页下划线样式的相关文章

巧用CSS自定义网页下划线样式

CSS为网页设计者们提供了丰富而灵活的页面元素表现形式的控制手段.但是,或许你可能注意到了,对于下划线,CSS提供的可选操作却不是很多.一般情况下,人们看到的下划线基本上都是横直线,缺少生气和灵动.不过,路并不是死的,通过一些绝妙的改造,我们还是可以做出富有创意的下划线来使页面更为美观. 这是一个自定义下划线的例子:自定义的下划线 .是不是很酷呢?除了能让你的网页呈现出一个与众不同的风格之外,它还能对于文档中不同的文字类型给与不同的视觉外观,起到提醒或者着重的作用. 下面我们就来一起学习如何自定

利用CSS,链接下划线也玩自定义

css|链接 由 A List Apart 杂志及作者授权翻译.(Translated with the permission of A List Apart Magazine and the author[s].) 说明:文章中"[补充]"内容系译者所补充添加(来自 CSS 2.0 中文手册),目的是方便读者理解相关内容. 虽然网页设计师通常有大量的方法控制文档如何呈现,但是基本的CSS不能为页面中链接下方的下划线样式提供很多选择.不过只需一点小技巧,你就能获得链接样式显示方式的创作

利用CSS,链接下划线也玩自定义_CSS/HTML

原文链接:CSS Design: Custom Underlines 由 A List Apart 杂志及作者授权翻译.(Translated with the permission of A List Apart Magazine and the author[s].) 说明:文章中"[补充]"内容系译者所补充添加(来自 CSS 2.0 中文手册),目的是方便读者理解相关内容. 虽然网页设计师通常有大量的方法控制文档如何呈现,但是基本的CSS不能为页面中链接下方的下划线样式提供很多选

Android如何自定义EditText下划线?_Android

曾经做过一个项目,其中登录界面的交互令人印象深刻.交互设计师给出了一个非常作的设计,要求做出包含根据情况可变色的下划线,左侧有可变图标,右侧有可变删除标志的输入框,如图 记录制作过程: 第一版本 public class LineEditText extends EditText { private Paint mPaint; private int color; public static final int STATUS_FOCUSED = 1; public static final in

CSS中的下划线text-decoration属性使用进阶

  定义和用法 text-decoration 属性规定添加到文本的修饰. 注释:修饰的颜色由 "color" 属性设置. 说明 这个属性允许对文本设置某种效果,如加下划线.如果后代元素没有自己的装饰,祖先元素上设置的装饰会"延伸"到后代元素中.不要求用户代理支持 blink. 默认值: none 继承性: no 可能的值 none 默认.定义标准的文本. underline 定义文本下的一条线. overline 定义文本上的一条线. line-through 定

CSS文字颜色不变下划线变颜色的实现

这里我们对3组文字设置三种不同颜色下划线,分别css命名为".divcss5-F00".".divcss5-00F".".divcss5-333" 二.使用css border实现字体下划线为实线还是虚线 - TOP 1.字体下划线颜色不同实现完整HTML源代码: <!DOCTYPE html>  <html>  <head>  <meta http-equiv="Content-Type&qu

Android 如何自定义EditText 下划线?

项目要求:  笔者曾经做过一个项目,其中登录界面的交互令人印象深刻.交互设计师给出了一个非常作的设计,要求做出包含根据情况可变色的下划线,左侧有可变图标,右侧有可变删除标志的输入框,如图  记录制作过程: 第一版本 public class LineEditText extends EditText { private Paint mPaint; private int color; public static final int STATUS_FOCUSED = 1; public stati

趣味知识:利用CSS进行网页制作中易被忽视的问题

css|网页|问题 关于这篇文章其实早就想写了,只是由于自己太懒才一直拖到现在.主要想谈谈在网页制作中几个比较容易被忽视的问题,算不上什么高深的教程,只是自己平时工作学习中所遇到的问题积累,写下来一是可以给初学者提个醒,二来也是帮自己做个笔录,毕竟年纪大了,记性不好了... 1.让你想当然,给你点颜色看看 这个问题其实被很多人忽略,小到个人站点,大到门户网站都有可能犯这个错误.不信想想看,如果你所做的网站背景是白色的,那么你还会记得在 CSS 里写下 Background-color:#ffff

Android如何自定义EditText下划线?

曾经做过一个项目,其中登录界面的交互令人印象深刻.交互设计师给出了一个非常作的设计,要求做出包含根据情况可变色的下划线,左侧有可变图标,右侧有可变删除标志的输入框,如图 记录制作过程: 第一版本 public class LineEditText extends EditText { private Paint mPaint; private int color; public static final int STATUS_FOCUSED = 1; public static final in