zoukankan      html  css  js  c++  java
  • 关于inline-block 元素之间为何会产生间隔

    关于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)
          // }
    
      };
    }

    所以我们去除掉这个节点就可以解决这个问题。就像注释的那段代码那样。其他的各种解决方案也有很多。这里不就介绍了。

    当然,如果我们工程化项目时会压缩代码这时候会去除一些换行和空格,这种问题也可以避免。

  • 相关阅读:
    PAT顶级 1002. Business (35)
    Codeforces Round #417 (Div. 2) B. Sagheer, the Hausmeister
    Codeforces Round #417 (Div. 2) C. Sagheer and Nubian Market
    主席树模板poj 2104
    Java 集合相关
    扁平疣病治疗
    一些网址
    在ubuntu14.04设置静态ip
    在Ubuntu14.04下安装vsftp服务器
    移植SDL运行库到Tiny6410 上
  • 原文地址:https://www.cnblogs.com/btgyoyo/p/6261860.html
Copyright © 2011-2022 走看看