如何将两个 div 并排放置?
Posted
技术标签:
【中文标题】如何将两个 div 并排放置?【英文标题】:How to place two divs next to each other? 【发布时间】:2011-08-13 18:23:45 【问题描述】:考虑following code:
#wrapper
width: 500px;
border: 1px solid black;
#first
width: 300px;
border: 1px solid red;
#second
border: 1px solid green;
<div id="wrapper">
<div id="first">Stack Overflow is for professional and enthusiast programmers, people who write code because they love it.</div>
<div id="second">When you post a new question, other users will almost immediately see it and try to provide good answers. This often happens in a matter of minutes, so be sure to check back frequently when your question is still new for the best response.</div>
</div>
我希望两个 div 在包装 div 内彼此相邻。在这种情况下,绿色 div 的高度应该决定 wrapper 的高度。
如何通过 CSS 实现这一点?
【问题讨论】:
还有:***.com/questions/446060/…#wrapper display: flex;
CSS two divs next to each other的可能重复
【参考方案1】:
浮动一个或两个内部 div。
浮动一个 div:
#wrapper
width: 500px;
border: 1px solid black;
overflow: hidden; /* will contain if #first is longer than #second */
#first
width: 300px;
float:left; /* add this */
border: 1px solid red;
#second
border: 1px solid green;
overflow: hidden; /* if you don't want #second to wrap below #first */
或者如果你同时浮动,你需要鼓励包装器 div
包含浮动的孩子,否则它会认为它是空的并且没有在它们周围放置边框
浮动两个 div:
#wrapper
width: 500px;
border: 1px solid black;
overflow: hidden; /* add this to contain floated children */
#first
width: 300px;
float:left; /* add this */
border: 1px solid red;
#second
border: 1px solid green;
float: left; /* add this */
【讨论】:
您可以在#wrapper 上设置overflow:auto
这样大小仍会适应内容大小。 (不需要 clear:both 元素)
是的,在示例一中,如果 #first 更长,您当然可以 - 包含浮动 101 eh ;).. 隐藏在 #second 上的溢出避免了计算左边距的需要,否则解决方案基本一样
没错!我不想计算保证金。 overflow: hidden
在这里做得很好!然而,它对我来说仍然是一种魔法。我认为overflow: hidden
应该隐藏不适合其容器的内容。但是,这里的行为有点不同。请您详细说明一下吗?
overflow
属性将清除垂直和水平浮动,这就是为什么在我的第一个示例中,#second
不需要左边距,只要它的值不是溢出属性就可以工作visible
.. 对于那些以防万一的情况,我更喜欢隐藏而不是自动,因此滚动条不会意外生成(自动会这样做).. 无论哪种方式,都不会隐藏任何内容,因为它只会是如果超出您的 500px 宽度,则隐藏,但只要没有高度,内容将正常包裹在宽度内.. 没有隐藏;)
#wrapper 上的 overflow:hidden 用于垂直包含 #first 浮动,如果它比非浮动的 #second div 长。 #second 上的第二个溢出用于包含第一个浮动旁边的内容,否则它会在第一个浮动下方。溢出属性的扩展行为在 CSS2.1 的某个地方分阶段进行,规范本身发生了变化,以响应在没有清除元素或 clearfix hack 的情况下包含浮动的方式,它的技术术语是当这样使用时,它会创建一个新的块格式化上下文【参考方案2】:
有两个 div,你也可以使用display
属性:
#wrapper
border: 1px solid blue;
#div1
display: inline-block;
width:120px;
height:120px;
border: 1px solid red;
#div2
display: inline-block;
width:160px;
height:160px;
border: 1px solid green;
<div id="wrapper">
<div id="div1">The two divs are</div>
<div id="div2">next to each other.</div>
</div>
如果div1
超过一定高度,div2
将被放置在底部div1
旁边。要解决此问题,请在 div2
上使用 vertical-align:top;
。
#wrapper
border: 1px solid blue;
#div1
display: inline-block;
width:120px;
height:120px;
border: 1px solid red;
#div2
vertical-align:top;
display: inline-block;
width:160px;
height:160px;
border: 1px solid green;
<div id="wrapper">
<div id="div1">The two divs are<br/><br/><br/><br/><br/><br/></div>
<div id="div2">next to each other.</div>
</div>
jsFiddle for example 1.
jsFiddle for example 2.
【讨论】:
@BSeven 接受的答案使用 float 属性,该属性早于主要浏览器的 display 属性支持。 Chrome 从 v1.0 开始支持浮动,从 v4.0 开始支持显示。也许接受的答案在编写时更加向后兼容。 这个解决方案有一个烦人的问题:因为div
s 是inline
,所以您必须在 html 中在它们之间保留任何空格、换行符等。否则,浏览器将在它们之间呈现一个空格。看到这个Fiddle:你不能设法让两个div
s 在同一行,除非你把他们的标签放在中间没有任何东西。【参考方案3】:
您可以使用 CSS 浮动属性让元素彼此相邻:
#first
float: left;
#second
float: left;
您需要确保包装器 div 允许在宽度方面进行浮动,并且边距等设置正确。
【讨论】:
【参考方案4】:尝试使用弹性盒模型。写起来简单又简短。
直播Jsfiddle
CSS:
#wrapper
display: flex;
border: 1px solid black;
#first
border: 1px solid red;
#second
border: 1px solid green;
默认方向是行。因此,它在#wrapper 内彼此相邻对齐。 但不支持IE9及以下版本
【讨论】:
【参考方案5】:选项 1
在两个 div
元素上使用 float:left
,并为两个 div 元素设置一个 % 宽度,总宽度为 100%。
在浮动 div 元素上使用 box-sizing: border-box;
。值border-box 强制填充和边框进入宽度和高度,而不是扩展它。
在<div id="wrapper">
上使用 clearfix 清除浮动的子元素,这将使包装器 div 缩放到正确的高度。
.clearfix:after
content: " ";
visibility: hidden;
display: block;
height: 0;
clear: both;
#first, #second
box-sizing: border-box;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
#wrapper
width: 500px;
border: 1px solid black;
#first
border: 1px solid red;
float:left;
width:50%;
#second
border: 1px solid green;
float:left;
width:50%;
http://jsfiddle.net/dqC8t/3381/
选项 2
在一个元素上使用position:absolute
,在另一个元素上使用固定宽度。
添加 position:relative to <div id="wrapper">
元素以使子元素绝对定位到 <div id="wrapper">
元素。
#wrapper
width: 500px;
border: 1px solid black;
position:relative;
#first
border: 1px solid red;
width:100px;
#second
border: 1px solid green;
position:absolute;
top:0;
left:100px;
right:0;
http://jsfiddle.net/dqC8t/3382/
选项 3
在两个 div
元素上使用 display:inline-block
,并为两个 div 元素设置一个 % 宽度,总宽度为 100%。
再次(与 float:left
示例相同)在 div 元素上使用 box-sizing: border-box;
。值border-box 强制填充和边框进入宽度和高度,而不是扩展它。
注意: inline-block 元素可能存在间距问题,因为它受 HTML 标记中的空格影响。更多信息在这里:https://css-tricks.com/fighting-the-space-between-inline-block-elements/
#first, #second
box-sizing: border-box;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
#wrapper
width: 500px;
border: 1px solid black;
position:relative;
#first
width:50%;
border: 1px solid red;
display:inline-block;
#second
width:50%;
border: 1px solid green;
display:inline-block;
http://jsfiddle.net/dqC8t/3383/
最后一个选项是使用名为 flex 的新显示选项,但请注意可能会影响浏览器兼容性:
http://caniuse.com/#feat=flexbox
http://www.sketchingwithcss.com/samplechapter/cheatsheet.html
【讨论】:
同意;float
不要让我的船浮起来。 inline-block
岩石。 (对不起。)【参考方案6】:
解决办法如下:
#wrapper
width: 500px;
border: 1px solid black;
overflow: auto; /* so the size of the wrapper is alway the size of the longest content */
#first
float: left;
width: 300px;
border: 1px solid red;
#second
border: 1px solid green;
margin: 0 0 0 302px; /* considering the border you need to use a margin so the content does not float under the first div*/
您的演示已更新;
http://jsfiddle.net/dqC8t/1/
【讨论】:
谢谢。如果我省略overflow: auto;
它仍然有效。你能举个例子吗?
是的,当然:删除溢出自动并使第一个的内容比第二个的内容长,你很清楚容器的大小只有在你设置溢出自动时才会适应,或者如果你使用了一个清除元素:jsfiddle.net/dqC8t/3
好的,我明白了,谢谢!但是,我不喜欢margin: 0 0 0 302px;
,因为它依赖于width: 300px;
。但是,无论如何,谢谢!
如果为第二个 div 指定 i 宽度,则不需要它【参考方案7】:
这很容易 - 你可以努力做到这一点
.clearfix:after
content: " ";
visibility: hidden;
display: block;
height: 0;
clear: both;
#first, #second
box-sizing: border-box;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
#wrapper
width: 500px;
border: 1px solid black;
#first
border: 1px solid red;
float:left;
width:50%;
#second
border: 1px solid green;
float:left;
width:50%;
<div id="first">Stack Overflow is for professional and enthusiast programmers, people who write code because they love it.</div>
<div id="second">When you post a new question, other users will almost immediately see it and try to provide good answers. This often happens in a matter of minutes, so be sure to check back frequently when your question is still new for the best response.</div>
</div>
或简单的方法
#wrapper
display: flex;
border: 1px solid black;
#first
border: 1px solid red;
#second
border: 1px solid green;
<div id="wrapper">
<div id="first">Stack Overflow is for professional and enthusiast programmers, people who write code because they love it.</div>
<div id="second">When you post a new question, other users will almost immediately see it and try to provide good answers. This often happens in a matter of minutes, so be sure to check back frequently when your question is still new for the best response.</div>
</div>
还有一百万种其他方式。 但我只是用简单的方法。 我还想告诉你,这里的很多答案都是不正确的 但我展示的这两种方式至少在 HTML 5 中有效。
【讨论】:
【参考方案8】:尝试使用下面的代码更改将两个 div 放在彼此的前面
#wrapper
width: 500px;
border: 1px solid black;
display:flex;
JSFiddle link
【讨论】:
【参考方案9】:这是正确的 CSS3 答案。希望这对您有所帮助:D 我真的很推荐你读这本书:https://www.amazon.com/Book-CSS3-Developers-Future-Design/dp/1593272863 其实我已经从现在读这本书得到了这个解决方案。 :D
#wrapper
display: flex;
flex-direction: row;
border: 1px solid black;
#first
width: 300px;
border: 1px solid red;
#second
border: 1px solid green;
<div id="wrapper">
<div id="first">Stack Overflow is for professional and enthusiast programmers, people who write code because they love it.</div>
<div id="second">When you post a new question, other users will almost immediately see it and try to provide good answers. This often happens in a matter of minutes, so be sure to check back frequently when your question is still new for the best response.</div>
</div>
【讨论】:
【参考方案10】:在两个 div 中添加 float:left;
属性。
添加display:inline-block;
属性。
在父 div 中添加 display:flex;
属性。
【讨论】:
【参考方案11】:我的做法:
<div class="left">Left</div>
<div class="right">Right</div>
CSS:
.left
float: left;
width: calc(100% - 200px);
background: green;
.right
float: right;
width: 200px;
background: yellow;
【讨论】:
干净简单。【参考方案12】:在 Material UI 和 react.js 中你可以使用网格
<Grid
container
direction="row"
justify="center"
alignItems="center"
>
<Grid item xs>
<Paper className=classes.paper>xs</Paper>
</Grid>
<Grid item xs>
<Paper className=classes.paper>xs</Paper>
</Grid>
<Grid item xs>
<Paper className=classes.paper>xs</Paper>
</Grid>
</Grid>
【讨论】:
【参考方案13】:#wrapper
width: 1200;
border: 1px solid black;
position: relative;
float: left;
#first
width: 300px;
border: 1px solid red;
position: relative;
float: left;
#second
border: 1px solid green;
position: relative;
float: left;
width: 500px;
<div id="wrapper">
<div id="first">Stack Overflow is for professional and enthusiast programmers, people who write code because they love it.</div>
<div id="second">When you post a new question, other users will almost immediately see it and try to provide good answers. This often happens in a matter of minutes, so be sure to check back frequently when your question is still new for the best response.</div>
</div>
【讨论】:
以上是关于如何将两个 div 并排放置?的主要内容,如果未能解决你的问题,请参考以下文章