获得本站免费赞助空间请点这里
返回列表 发帖

自定多姿多彩的网页链接下划线

CSS本身没有直接提供变换HTML链接下划线的功能,但只要运用一些技巧,我们还是可以让单调的网页链接下划线变得丰富多彩。   一、基本原理 & \0 `& E) D7 n4 g- Q8 X* v' K9 @
  首先,自定义HTML链接下划线的第一步是创建一个图形,在水平方向重复放置这个图形即形成下划线效果。如果要显示出下划线背后的网页背景,可以使用透明的.gif图形。
/ _8 x8 l2 p9 H* @! t4 w
8 S8 {# [/ ~/ W: c* D# L* z# K  其次,如果下划线图形的高度较大,则必须适当增加文本的高度,使得一行文本的底部与下一行文本的顶部之间有较大的空间,例如p { line-height: 1.5; }。+ q4 R+ L: L) l/ j% L  N+ d

3 Q- j" Q1 h4 K) v  第三,为显示出自定义的下划线,必须隐藏默认的下划线,即a { text-decoration: none; }。
: Y5 r3 X7 o4 F1 Q. Z/ P* c" ?- j/ f# `5 D7 [; e
  第四,为链接元素设置下划线图形,构造出自定义的下划线。假设下划线图形是underline.gif,则设置下划线图形的CSS代码为a { background-image: url(underline.gif); }。
4 a& v8 a; I% }* {& A- a9 A- h  z* Q1 P' V& L! Y" [6 D
  第五,我们要让下划线图形在水平方向反复出现,但不能在垂直方向重复出现,否则它将被隐藏到文本的背后。要求下划线只在水平方向重复出现的代码为:a { background-repeat: repeat-x; }。
) I  ?; g* t. O4 R+ `" r  A& V! ^
  第六,为保证图形出现在链接文字的下方(不管字体的大小),用background-position属性将图形放在链接元素的底部。对于箭头之类的下划线图形,可能还要考虑图形在水平方向的对齐方向。假设要将下划线图形放在右下角,CSS代码为:a { background-position:100% 100%; }。
! H2 c0 _5 j7 G1 z7 q6 @& C3 o0 q. r3 j9 d
  第七,为了在链接文本的下方给自定义图形留出空间,必须加入适当的空白。下划线图形相对于链接文字的具体位置与文字的大小有关,但一般而言,可以先让底部空白等于下划线图形的高度,必要时再作调整。例如:a { padding-bottom: 4px; }。
% S# k7 e. L4 i. Q8 B8 ^2 s
6 u; g. J9 v1 x- t' x. Z- @  第八,由于下划线图形放在链接元素的底部,必须保证链接不折行(如允许链接跨越多个行,则只有下面一行的链接文本下面会有自定义的下划线)。用CSS的white-space属性可以防止链接文字折行,即a { white-space: nowrap; }。: V  E) P: b9 r6 g6 p2 [6 E% D

, C8 p8 R. d: B: e$ D% m  综上所述,为链接元素定义CSS样式属性的完整例子如:' i$ D% L& j- w+ @

# j/ e8 D3 r  N: d+ p  a {
3 A& t- Z* z) d# G  c, |/ d   text-decoration: none;
4 y9 k. Y3 w7 R. j; \& X* b   background: url(underline.gif) repeat-x 100% 100%;
7 r( @. w  R  O1 f7 y   padding-bottom: 4px;
  m, u! m1 S# x; y8 \   white-space: nowrap;
! r0 k8 x8 u6 [$ e* P" \' n  }   如果要让自定义下划线只在鼠标停留时出现,只要把原来直接设置在链接元素上的CSS background属性改到:hover ,例如:& X4 E9 S8 u* w, @6 C  N
  a {
" i8 l4 }+ B. I0 J6 v) |   text-decoration: none;: R7 {* r8 j, d( s: D0 l. ~
   padding-bottom: 4px;
7 ?4 k- j* n: S   white-space: nowrap;
% g  w* D) ]6 }5 ~% V$ z  W; n  }2 u; h4 O0 \6 @5 u. O  e
  a:hover {
4 }$ r! A& J" I% u+ @   background: url(underline.gif) repeat-x 100% 100%;
0 w8 v' K6 u) G8 U  }

返回列表
【捌玖网络】已经运行: