首页IT科技display inline block有什么好处(关于 display: inline-block; 中间有间隙的问题)

display inline block有什么好处(关于 display: inline-block; 中间有间隙的问题)

时间2025-06-14 09:10:01分类IT科技浏览4632
导读:当我们给一个元素的一系列子元素设置display: inline-block; 时,会发现子元素之间存在间隙,如...

当我们给一个元素的一系列子元素设置display: inline-block; 时             ,会发现子元素之间存在间隙                    ,如

页面显示是这样的      ,中间为何会有一条间隙呢?我们先用js获取到section       ,然后打印一下它的子节点                    ,如下

let sec = document.querySelector(section) let children = sec.childNodes console.log(children)

打印结果页面显示为

可以看出             ,我们只有两个div       ,但是打印出来七个节点                    ,这是因为             ,在我们的HTML中,不止标签是一个节点                    ,注释                    ,文本,换行都是节点             ,上面四个text节点便为换行的文本节点                    ,      ,comment为注释节点              。当我们把鼠标移动到第二个text上时             ,如图所示

我们看到                    ,当选中第二个text节点时      ,页面上的空隙呈现高亮效果       ,所以                    ,我们到此可以判断             ,空隙是由于换行引起的text节点导致的                   。

那么       ,我们尝试下把这个text去掉

<section> <div></div><!-- 这是一个注释 --> <div></div> </section>

再次打印                    ,如图所示

现在变成注释节点后面的text高亮了             ,所以,我们再次去掉comment后面的text节点

<div></div><!-- 这是一个注释 --><div></div>

再次打印                    ,如图所示

现在空隙消失了      。需要注意的是                    ,空格也会出现text节点              。

当然,以去掉换行的方式去掉文本节点有时会不太好             ,我们也可以用js去掉

let sec = document.querySelector(section) let children = sec.childNodes let i = 0 while(i < children.length) { if(children[i].nodeType === 3) { sec.removeChild(children[i]) } else { i++ } } console.log(children)

如图所示

嗯                    ,因为文本节点的nodeType为3      ,所以我们移除nodeType为3的节点就可以实现去掉text节点了             ,这样子就可以在页面上写换行了                    ,如此做的缺点是:①子元素必须不需要文本节点                    。②需要写JS代码动态去除      。

声明:本站所有文章      ,如无特殊说明或标注       ,均为本站原创发布       。任何个人或组织                    ,在未征得本站同意时             ,禁止复制              、盗用                   、采集      、发布本站内容到任何网站              、书籍等各类媒体平台                    。如若本站内容侵犯了原著者的合法权益       ,可联系我们进行处理             。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
win10商店改下载位置(win10商店下载位置更改后还是下载在C盘解决教程) 如何让你的网站在搜索引擎中脱颖而出(从零开始学习排名优化)