关于inline-block 元素之间为何会产生间隔
2017-01-08 13:19
435 查看
关于inline-block 元素之间为何会产生间隔
现象:<body> <input type="text"> <input type="text"> </body>
在浏览器中的表现:
实时上不仅仅是 inline-block 会导致这种现象。 inline 也会导致。
那问题来了,为啥?
XML 经常在节点之间含有换行或空白字符。这是在使用简单的编辑器(比如记事本)时经常出现的情况。 下面的例子(由记事本编辑)在每行之间含有 CR/LF,
<body> <input type="text"> <input type="text"> </body>
DOM 规范中规定,一切皆是节点,换行或者空格,会被当成文档节点来处理。#text
所以那个空隙就是这个空的文档节点导致。
window.onload = function() { for (var i = document.body.childNodes.length - 1; i >= 0; i--) { var node = document.body.childNodes[i]; console.log(node) // if(node.nodeType==3){ // document.body.removeChild(node) // } }; }
所以我们去除掉这个节点就可以解决这个问题。就像注释的那段代码那样。其他的各种解决方案也有很多。这里不就介绍了。
当然,如果我们工程化项目时会压缩代码这时候会去除一些换行和空格,这种问题也可以避免。
相关文章推荐
- 【转】行内元素和inline-block产生的水平空隙bug
- 定义为inline-block的元素li消除li之间额外的间距
- 多种去除inline-block元素之间的间隙解决方法详解
- inline-block 元素之间的空白问题
- 关于css中的block元素inline元素 以及positison属性的初步认识。
- inline-block元素之间空白间距的解决办法
- 使用font-size:0 来去掉inline-block元素之间的空隙
- Study《去掉HTML中Inline-Block元素之间的空白》
- 消除button或inline-block元素之间的空白间距
- 清除inline-block元素之间的空白
- 5种方法去掉HTML中Inline-Block元素之间的空白
- inline-block横向排列元素间隔原因及去除间隔方法
- 处理inline元素之间换行产生的空白
- inline-block元素间间隙产生及去除详解
- 去除内联元素(inline-block元素)之间的间距
- display:inline-block 元素之间由于换行所产生的间距问题
- 5种方法去掉HTML中Inline-Block元素之间的空白
- 使用font-size:0 来去掉inline-block元素之间的空隙方法
- inline-block元素与父div底边之间的间距问题(inline-block与vertical-align:baseline)