  
- UID
- 1
- 帖子
- 738
- 精华
- 28
- 积分
- 14171
- 金币
- 2376
- 威望
- 1647
- 贡献
- 1324
|
CSS本身没有直接提供变换HTML链接下划线的功能,但只要运用一些技巧,我们还是可以让单调的网页链接下划线变得丰富多彩。 一、基本原理 , r% B4 A% X4 B9 ^0 D( h/ [
首先,自定义HTML链接下划线的第一步是创建一个图形,在水平方向重复放置这个图形即形成下划线效果。如果要显示出下划线背后的网页背景,可以使用透明的.gif图形。2 i$ a4 s' }+ H, v: T8 }
* v6 ^7 E2 O# ]- U* R( N. M' x5 A 其次,如果下划线图形的高度较大,则必须适当增加文本的高度,使得一行文本的底部与下一行文本的顶部之间有较大的空间,例如p { line-height: 1.5; }。
: V8 h9 M: T t7 f& {
% W& h6 r7 E5 v9 P" g \7 U& A 第三,为显示出自定义的下划线,必须隐藏默认的下划线,即a { text-decoration: none; }。
4 ^2 K" P5 n, ?0 l
8 B" m/ @; e: b, |4 q! d8 F 第四,为链接元素设置下划线图形,构造出自定义的下划线。假设下划线图形是underline.gif,则设置下划线图形的CSS代码为a { background-image: url(underline.gif); }。5 [' j" y! R) k! W
, C6 w+ g0 i$ u 第五,我们要让下划线图形在水平方向反复出现,但不能在垂直方向重复出现,否则它将被隐藏到文本的背后。要求下划线只在水平方向重复出现的代码为:a { background-repeat: repeat-x; }。! _/ `- G) u* F( v
9 y; q- L0 I) t8 v- ^# i 第六,为保证图形出现在链接文字的下方(不管字体的大小),用background-position属性将图形放在链接元素的底部。对于箭头之类的下划线图形,可能还要考虑图形在水平方向的对齐方向。假设要将下划线图形放在右下角,CSS代码为:a { background-position:100% 100%; }。
* O$ T' u2 T7 I6 I7 s: F# I5 Y, c6 M" }- g3 z2 C b) `7 p
第七,为了在链接文本的下方给自定义图形留出空间,必须加入适当的空白。下划线图形相对于链接文字的具体位置与文字的大小有关,但一般而言,可以先让底部空白等于下划线图形的高度,必要时再作调整。例如:a { padding-bottom: 4px; }。: H: f8 J! a1 u$ e9 p% D( c: R1 o
, T9 \/ z8 d, z) }
第八,由于下划线图形放在链接元素的底部,必须保证链接不折行(如允许链接跨越多个行,则只有下面一行的链接文本下面会有自定义的下划线)。用CSS的white-space属性可以防止链接文字折行,即a { white-space: nowrap; }。
/ f" l" D$ y. L+ d8 r
% j" t, M# ~) j _- d7 R; K* } 综上所述,为链接元素定义CSS样式属性的完整例子如:; g$ l( I+ T7 q9 r
9 W6 E/ G# q4 X# k a {, h) u2 K$ f3 Z t! u. x0 n
text-decoration: none; 4 W* d$ P1 ~6 n0 S
background: url(underline.gif) repeat-x 100% 100%;; q9 B ]& \7 C3 q8 A7 p2 p
padding-bottom: 4px;
, \& M/ ^1 j |7 u; T. c9 Z( q white-space: nowrap;
7 n, [9 Y5 m" f& [1 Q. `+ g } 如果要让自定义下划线只在鼠标停留时出现,只要把原来直接设置在链接元素上的CSS background属性改到:hover ,例如:
! V+ `* i" P" O* {& X6 l a {* k1 o0 W4 J6 t, P' m
text-decoration: none;, W I) F: h$ t) k' e
padding-bottom: 4px;; J9 g( Q* V) }
white-space: nowrap;
& U9 e4 V8 n$ }0 t }/ X: T* E4 M; V, e+ c
a:hover {
4 U3 X( B: s" {) T; j$ l( H4 ] background: url(underline.gif) repeat-x 100% 100%;
# {0 `( z) R) m( R, w } |
|