首页 > 代码库 > [转]CSS: inline-block的应用和float块高度塌陷
[转]CSS: inline-block的应用和float块高度塌陷
display:inline-block; /* 现代浏览器 +IE6、7 inline 元素 */ *display:inline; /* IE6、7 block 元素 */ *zoom:1;
注:*是CSS hack 告知IE6、IE7调用
HTML 中的换行符、空格符、制表符等产生了空白符,而这些归根结底都是字符,那么它们的大小都是受 font-size 来控制的,所以认为空隙是固定的想法是错误的。所以调整空隙可以用font-size:0。当对与chorme这样的早期浏览器有最小字大小时(自chorme19后就支持font-size:0),我们可以用 -webkit-text-size-adjust:none来设置,但是会直接导致页面文字无法缩放,这对于用户来说显然是不友好的,所以要确保使用地方没有大面积文字。
- Safari 5 依旧不支持 font-size:0 。6支持
- Firefox12,Opera 10 ,这次表现不错,支持 font-size:0 。
- IE8 以上支持 font-size:0;
- IE6、7 inline 元素 inline-block 后设置 font-size:0 始终有 1px 的空隙。
在IE6 IE7中不产生空格原因:
那么为何 IE6、7 block 元素没有产生空隙呢?其实前面也提到了 IE 的 hasLayout,具有独立性,所以产生 hasLayout 的元素之间表现出来互不影响,这也再次表明 IE6、7 中的 inline-block 不能等同于 CSS2.1 中的 inline-block。
具体步骤:
第一步:使用 font-size:0
经测试发现,chrome、firefox、IE8+、opera,inline 或 block 元素都没有空隙了;
IE6、7、8(Q),inline 元素 inline-block 后始终存在 1px 左右的空隙。
第二步:可以用letter-spacing:负值来调整
Safari 中 letter-spacing 负值的绝对值大于空隙大小后,内部会发生重叠。
第三步:word-spacing来调整IE6 7的1px 空隙
letter-spacing 和 word-spacing 同时使用可能导致冲突,所以我们需要在 IE6、7 中 hack 掉 letter-spacing。
white-space:normal | pre | nowrap | pre-wrap | pre-line
默认值:normal
- normal:默认处理方式。
- pre:用等宽字体显示预先格式化的文本,不合并文字间的空白距离,当文字超出边界时不换行。可查阅 pre 对象
- nowrap:强制在同一行内显示所有文本,直到文本结束或者遭遇 br 对象。
- pre-wrap:用等宽字体显示预先格式化的文本,不合并文字间的空白距离,当文字碰到边界时发生换行。
- pre-line:保持文本的换行,不保留文字间的空白距离,当文字碰到边界时发生换行。
父元素代码:
font-size:0;/* 所有浏览器 */letter-spacing:-5px;/* Safari 等不支持字体大小为 0 的浏览器 */*letter-spacing:normal;word-spacing:-1px;/* IE6、7 */
第四部,以上都是对父元素操作,子元素要重置正常值
子元素字体大小为0了,子元素显示为空。同时字符间距和单词间距重置为默认值
子元素代码:
font-size: 12px; letter-spacing: normal; word-spacing: normal;」
[转]CSS: inline-block的应用和float块高度塌陷