CSS中的边距和填充有什么区别?在何种情况下:
两者都有效。只有保证金是合适的。只有填充是合适的。
CSS中的边距和填充有什么区别?在何种情况下:
两者都有效。只有保证金是合适的。只有填充是合适的。
当前回答
边距在框外,填充在框内
其他回答
边距在框外,填充在框内
首先,让我们看看有什么不同,以及每个责任是什么:
1) 保证金CSS边距财产用于在元素周围生成空间。边距财产设置了边境使用CSS,您可以完全控制边距。有用于设置元素每边边距的CSS财产(顶部、右侧、底部和左侧)。
2) 衬垫CSS填充财产用于在内容周围生成空间。填充将清除内容(边框内)周围的区域元素。使用CSS,您可以完全控制填充。那里是CSS财产,用于设置元素每一侧的填充(顶部、右侧、底部和左侧)。
所以简单地说,边距是元素周围的空间,而填充是元素内容周围的空间。
这张来自codemancers的图片显示了边距和边框是如何结合的,以及边框和内容框是如何使其不同的。
此外,他们对每个部分的定义如下:
内容-这定义了文本、图像或其他元素等实际内容所在的框的内容区域。填充-这将清除其包含框中的主要内容。边框-它包围内容和填充。边距-此区域定义一个透明空间,将其与其他元素分隔开。
TL;DR:默认情况下,我在任何地方都使用边距,除非我有边框或背景,并且希望增加可见框内的空间。
对我来说,填充和边距之间的最大区别是垂直边距会自动折叠,而填充不会。
考虑两个元素,一个在另一个之上,每个元素的填充为1米。此填充被视为元素的一部分,并始终保留。
因此,您将以第一个元素的内容结尾,然后是第一个元素填充,然后是第二个元素的填充,最后是第二元素的内容。
因此,这两种元素的含量最终将相距2米。
现在用1毫米的边距替换填充。边距被认为在元素之外,相邻项目的边距将重叠。
因此,在本例中,您将得到第一个元素的内容,然后是1em的组合边距,然后是第二个元素的属性。因此,这两种元素的含量仅相差1米。
当你知道你想说一个元素周围有1em的间距,而不管它旁边是什么元素时,这会非常有用。
另外两个大的区别是,填充包括在点击区域和背景色/图像中,但不包括边距。
div.box>div{height:50px;width:50px,border:1px纯黑;text-align:center;}div.padding>div{padding-top:20px;}div.margin>div{margin-top:20px;}<h3>默认值</h3><div class=“box”><div>A</div><div>B</div><div>C</div></div><h3>顶部填充:20px</h3><div class=“box padding”><div>A</div><div>B</div><div>C</div></div><h3>页边空白:20px</h3><div class=“box margin”><div>A</div><div>B</div><div>C</div></div>
这里有一些HTML演示了填充和边距如何影响可点击性和背景填充。一个对象会收到对其填充的点击,但对对象空白区域的点击会转到其父对象。
$(“.other”).click(函数(e){console.log(“外部”);e.停止传播();});$(“.intern”).click(函数(e){console.log(“内部”);e.停止传播();});.外部{填充:10px;背景:红色;}.内部{边距:10px;填充:10px;背景:蓝色;边框:纯白1px;}<script src=“http://code.jquery.com/jquery-latest.js“></script><div class=“outer”><div class=“inner”style=“位置:相对;高度:0px;宽度:0px”></div></div>
高级边距与填充说明
使用填充来分隔元素中的内容是不合适的;您必须在子元素上使用margin。较旧的浏览器(如Internet Explorer)误解了框模型,除非它使用了在Internet Explorer 4中完美工作的边距。
使用填充时有两个例外:
它应用于不能包含任何子元素(如输入元素)的内联元素。您正在补偿一个非常复杂的浏览器错误,供应商*咳嗽*Mozilla*咳嗽*拒绝修复该错误,并且确信(在一定程度上,您与W3C和WHATWG编辑保持定期交流)您必须有一个有效的解决方案,该解决方案不会影响除您正在补偿的错误之外的任何其他问题的样式。
当你有一个带有填充的100%宽度元素时:50px;您可以有效地获得width:calc(100%+100px);。由于未将边距添加到宽度中,因此在子元素上使用边距而不是直接在元素上填充时,不会导致意外的布局问题。
因此,如果您不执行这两项操作之一,请不要向元素添加填充,而是向它的直接子/子元素添加填充以确保在所有浏览器中都能获得预期的行为。