gpt4 book ai didi

html - 为什么我的 div 和按钮之间有间隙

转载 作者:太空宇宙 更新时间:2023-11-03 23:53:28 24 4
gpt4 key购买 nike

有几天我使用 CSS 尝试定位和调整大小,但我被 div 元素和按钮元素之间的间隙困住了。

Illustration of the gap problem主要的持有 div 具有绿色背景,而包含的 div 的持有者具有粉红色背景。

所以你可以看到 div 作为标签和文本框持有者之间存在差距,并且在放置在 div 内的按钮作为按钮持有者之间也存在差距

我还尝试包含一个 css 重置但没有成功,我还尝试放置一个全局选择器来重置填充边距和边框

* {
padding:0;
margin : 0
border-width: 0;
}

我真的很想知道如何消除这些差距,让我的持有人完全控制占用的空间。在所有情况下,这是我非常简单的代码。

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<style>
.interactput {
background-color: green;
}

.interactput div {
display: inline-block;
overflow: hidden;
vertical-align: middle;
background-color: lightpink;
}

.interactput div button {
background-color: lightgoldenrodyellow;
}
</style>

</head>
<body>
<div id="AddessEditor" class="interactput">
<div>
<label>This is a label inside a div</label>
</div>
<div>
<input type="text" value="This is input type=text inside a div"/>
</div>
<div>
<button>We are</button>
<button>Three buttons</button>
<button>Inside a div</button>
</div>

</div>
</body>
</html>

最佳答案

终于在这里找到了确切的原因fighting the space between inline block elements .

正如您在 css trick 的建议文章中所读到的,具有内联 block 显示模式的元素之间有一个空格,因为它们之间有一个空格或换行符,浏览器会将其转换为文本节点。就我自己而言,建议的解决方案绝对不是易于理解和/或维护的解决方案。

因此,经过几个小时的谷歌搜索,正确制定问题的问题:S 我发现可以使用 JQuery 轻松消除那些文本节点。答案在 stackoverflow 上 Solution to remove text node .因此,让我们以我提交的代码示例为我的控件容器创建一个特定的类,我将其命名为“control-container”。

    <div id="AddessEditor" class="interactput">
<div class="control-container">
<label>This is a label inside a div</label>
</div>
<div class="control-container">
<input type="text" value="This is input type=text inside a div"/>
</div>
<div class="control-container">
<button>We are</button>
<button>Three buttons</button>
<button>Inside a div</button>
</div>
</div>

在这之后,我所要做的就是从那些容器中过滤掉文本节点,并在文档就绪函数中像这样删除它们......

$(document).ready( function() {
$('.interactput').contents().filter(function () { return this.nodeType === 3; }).remove();
$('.control-container').contents().filter(function () { return this.nodeType === 3; }).remove();
});

魔法!这非常适合我的需要,因为我正在创建一个小部件。希望它能帮助这里的其他人

关于html - 为什么我的 div 和按钮之间有间隙,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19318251/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com