|
  
- UID
- 1
- 帖子
- 738
- 精华
- 28
- 积分
- 14325
- 金币
- 2448
- 威望
- 1647
- 贡献
- 1396
|
CSS本身没有直接提供变换HTML链接下划线的功能,但只要运用一些技巧,我们还是可以让单调的网页链接下划线变得丰富多彩。 一、基本原理
$ z2 {4 u. x; K. `5 j7 }7 Z 首先,自定义HTML链接下划线的第一步是创建一个图形,在水平方向重复放置这个图形即形成下划线效果。如果要显示出下划线背后的网页背景,可以使用透明的.gif图形。
" ^- K+ }6 T5 L2 t# ^" B
$ J. G- U% K. u7 c; P6 e) d 其次,如果下划线图形的高度较大,则必须适当增加文本的高度,使得一行文本的底部与下一行文本的顶部之间有较大的空间,例如p { line-height: 1.5; }。
f6 o6 c/ Z. ^2 I# r, {% w& w$ X- o; {) l1 e
第三,为显示出自定义的下划线,必须隐藏默认的下划线,即a { text-decoration: none; }。
' w! P/ b, M# h$ P; O6 F5 |, m1 R; j' M2 I# p+ E
第四,为链接元素设置下划线图形,构造出自定义的下划线。假设下划线图形是underline.gif,则设置下划线图形的CSS代码为a { background-image: url(underline.gif); }。
( J' r" V% g. v! C3 V+ \6 s; ~. }1 D9 V, \% y1 @ s2 Z
第五,我们要让下划线图形在水平方向反复出现,但不能在垂直方向重复出现,否则它将被隐藏到文本的背后。要求下划线只在水平方向重复出现的代码为:a { background-repeat: repeat-x; }。1 B# Y0 l: O' C
0 I8 o6 O q S& D 第六,为保证图形出现在链接文字的下方(不管字体的大小),用background-position属性将图形放在链接元素的底部。对于箭头之类的下划线图形,可能还要考虑图形在水平方向的对齐方向。假设要将下划线图形放在右下角,CSS代码为:a { background-position:100% 100%; }。
2 R: p, a7 h+ f e n; k" x+ r/ `+ R1 F' b
第七,为了在链接文本的下方给自定义图形留出空间,必须加入适当的空白。下划线图形相对于链接文字的具体位置与文字的大小有关,但一般而言,可以先让底部空白等于下划线图形的高度,必要时再作调整。例如:a { padding-bottom: 4px; }。# I7 a$ y9 m& o& `7 ?9 R6 r
# n, x& g$ c! H2 `7 j
第八,由于下划线图形放在链接元素的底部,必须保证链接不折行(如允许链接跨越多个行,则只有下面一行的链接文本下面会有自定义的下划线)。用CSS的white-space属性可以防止链接文字折行,即a { white-space: nowrap; }。# S) O7 v* u7 Q d
; ^) o) t0 z6 h3 a 综上所述,为链接元素定义CSS样式属性的完整例子如:2 Z& W# I- j6 @$ G* i
1 v/ U$ z5 G1 S# p' Y) C a {
0 p3 J( a" Q2 U4 n* a2 ]/ p8 m text-decoration: none;
& o! M# D4 p* t2 y7 \" F background: url(underline.gif) repeat-x 100% 100%;
' h4 O$ L9 s: c+ t# ` padding-bottom: 4px;
2 o; O7 x* D% M7 j, J& H0 ]1 I1 o white-space: nowrap;* _, Y8 M! B9 t, o
} 如果要让自定义下划线只在鼠标停留时出现,只要把原来直接设置在链接元素上的CSS background属性改到:hover ,例如:
2 w7 j3 c h* K4 x2 e a {8 X- D$ t. ?$ ?+ N# B& q" U" u
text-decoration: none;6 v8 s6 @) I9 k. D$ J
padding-bottom: 4px;
9 a0 A9 z+ S/ y! s+ H/ o! ^2 } white-space: nowrap;: i; s ~# }) Q2 L/ J9 V
}
9 r" U( e/ z: H6 F# w4 K- n! W1 C a:hover {
7 \& [" F I* H5 ^! w3 O: p$ j background: url(underline.gif) repeat-x 100% 100%;
; z: F4 ]' o3 J0 [; k2 e+ V& ] } |
|