页面排版的时候经常会遇到li包含img时,图片文件的下边缘出现大概5个或10个像素的间隙,出现间隙大概是以下原因:
! N6 h! g. j- r0 p2 n7 e图片文字等inline元素默认是和父级元素的baseline对齐的,而baseline又和父级底边有一定距离(这个距离和 font-size,font-family 相关,不一定是 5px),所以设置 vertical-align:top/bottom/text-top/text-bottom 都可以避免这种情况出现。而且不光li,其他的block元素中包含img也会有这个现象,只要是inline元素和父级元素是baseline的属性的对齐。
+ L& B/ d z" Xhtml会把图片默认为内联级元素和文字是一样的,那文字的话,给他设置不同的文字大小或字体,肯定会有不同的行高,或者它们会有默认的行高。这样就有了img下面的空隙。; W4 t( z! \& @
具体解决办法:
" [2 B$ K8 d/ a9 n# c" W( {第一,给图片img标签display:block。
2 O* B. t1 v T1 img {display:block}
$ U6 `: F% m% V# W第二,定义容器里的字体大小为0。
, U ?" [+ Y7 }5 x. D1 div {
, N! ?' C# o. ~' D4 d* b' w( j( |, m2 width:110px;0 R# ^$ j) v( [1 C" N
3 border:1px solid #000;
: o" l: C# o) i u/ h# K1 `4 font-size:00 v, ^ y" R7 I' B2 f
5 }
% b/ h/ B6 |7 W. s# c* ^0 a: i第三,定义图片img标签vertical-align:bottom,vertical-align:middle,vertical-align:top4 f, ]8 h0 P7 u" ^+ [
1 img{vertical-align:bottom;}* H5 Y, Z. c6 }% `
至于html属性align=”center”(对于图片浏览器会处理成align=”middle”)的解决办法,就相当于vertical-align:middle; 所以道理也是一样的,只要vertical-align不取baseline,这个空隙就消失了。0 j! l, j& Q( E" x, H7 U- d( T
相关说明
^7 ?2 \. F" ]! A7 _6 Y D1.ie的显示有几种模式,在html文档的开始部分声明<!doctype ….>" R! ]- i2 F5 P2 q" V! w% l
如果声明为strict模式,ie以w3c的方式显示文档,而w3c的标准里面<img />默认是一个inline的标签,除非自己显式的声明为 block.- k& D6 E6 T% c; | h( n
2.那个空隙是ie针对盒模型默认的line-height和font-size. 给img desplay:block;虽然能解决问题,但没从结构上来考虑.可谓治标不治本.* m6 l# J* ]1 v m+ O. ^
1 [/ x: ^7 m: g, t: g4 }
更多网页制作信息请查看: 网页制作 |
|