页面排版的时候经常会遇到li包含img时,图片文件的下边缘出现大概5个或10个像素的间隙,出现间隙大概是以下原因:
5 k3 ^" G' A9 w! I' i图片文字等inline元素默认是和父级元素的baseline对齐的,而baseline又和父级底边有一定距离(这个距离和 font-size,font-family 相关,不一定是 5px),所以设置 vertical-align:top/bottom/text-top/text-bottom 都可以避免这种情况出现。而且不光li,其他的block元素中包含img也会有这个现象,只要是inline元素和父级元素是baseline的属性的对齐。9 T7 `9 z6 ~% \5 O9 [! w" Q: [
html会把图片默认为内联级元素和文字是一样的,那文字的话,给他设置不同的文字大小或字体,肯定会有不同的行高,或者它们会有默认的行高。这样就有了img下面的空隙。
1 C7 A: G# v: A3 f具体解决办法:) e+ E0 J; p+ O' R6 a. G: W7 i
第一,给图片img标签display:block。& @) e( a. u: X
1 img {display:block}
2 J& L' W# N5 W. w& k: z第二,定义容器里的字体大小为0。
) J% e5 o3 j6 ^( g- R1 div {
& Z; O z4 E/ E" }$ ~9 K1 H1 g2 width:110px;
+ J) B2 f. l3 Q6 R/ S5 C3 border:1px solid #000;
+ Y- m4 L2 f' J+ m/ n2 z4 font-size:0. a. S' s. t' u. q+ v; X
5 }
) _8 c' n9 ~: Y/ i第三,定义图片img标签vertical-align:bottom,vertical-align:middle,vertical-align:top4 P( X, u4 N1 ]' d/ H
1 img{vertical-align:bottom;}
8 c s# E" Y* \# O$ {+ T至于html属性align=”center”(对于图片浏览器会处理成align=”middle”)的解决办法,就相当于vertical-align:middle; 所以道理也是一样的,只要vertical-align不取baseline,这个空隙就消失了。
' q" J( j, H/ p. g+ K: Z- R. C相关说明
& d$ F! B/ K- F2 F9 P1.ie的显示有几种模式,在html文档的开始部分声明<!doctype ….>* ]9 C* B9 S! X' D) { ~
如果声明为strict模式,ie以w3c的方式显示文档,而w3c的标准里面<img />默认是一个inline的标签,除非自己显式的声明为 block.
5 D. O( Q1 F$ {* w2.那个空隙是ie针对盒模型默认的line-height和font-size. 给img desplay:block;虽然能解决问题,但没从结构上来考虑.可谓治标不治本.
5 I3 e* g9 c3 w3 a6 F7 O8 y) L, [; u. u: h
更多网页制作信息请查看: 网页制作 |
|