我要实现的目标:将容器div(包含两个div)居中,在第二个div中,底部对齐文本
在我的第二个div中,两段文字
———————-----
| |
| | column2
| column1 | -———————-------
| picture | | Paragraph |
| | ———————--------
| | ———————————------------------
| | | a paragraph of text |
| | | of text of text of text of |
——————----—— ———————----------------------
我的问题:
我无法将我的两个段落放在底部。他们在顶部。
我的容器div也未与中心对齐
当前它们看起来像这样:
———————----- -———————-------
| picture | | Paragraph |
| | ———————--------
| | ———————————------------------
| | | a paragraph of text |
| | | of text of text of text of |
| | ———————----------------------
| |
| |
| |
------------
我当前的代码:
<body>
<div class="container">
<div class="img column1">
<img id="img" src="https://animage.jpg">
</div>
<div class="comment column2">
<p>a paragraph</p>
<p>another paragraph</p>
</div>
</div>
</body>
.column1, .column2{
width:300px;
float: left;
margin: 10px;
}
#img{
max-width: 300px;
max-height: 600px;
}
.container {
width: 80%;
padding-top: 100px;
margin: 0 auto;
}
答案 0 :(得分:5)
将align方法更改为Flex,可以轻松实现,请看下面
只需删除列元素上的float: left
,然后在容器中添加display: flex
和align-items: flex-end
。
.column1, .column2{
width:300px;
margin: 10px;
}
#img{
max-width: 300px;
max-height: 600px;
}
.container {
width: 80%;
padding-top: 100px;
margin: 0 auto;
display: flex;
align-items: flex-end;
}
<body>
<div class="container">
<div class="img column1">
<img id="img" src="https://placeimg.com/200/200/any">
</div>
<div class="comment column2">
<p>a paragraph</p>
<p>another paragraph</p>
</div>
</div>
</body>
答案 1 :(得分:1)
.container{display:flex;}
.column1, .column2{
width:200px;
margin: 10px;
border:solid 1px #ccc;
flex-direction:column;
}
.column2{
justify-content:flex-end;
display:flex;
}
#img{
max-width: 100%;
}
p{ margin:0;}
.container {
width: 80%;
padding-top: 100px;
margin: 0 auto;
}
<div class="container">
<div class="img column1">
<img id="img" src="">
</div>
<div class="comment column2">
<p>a paragraph</p>
<p>another paragraph</p>
<p>another paragraph</p> <p>another paragraph</p>
</div>
</div>
答案 2 :(得分:1)
对此最简单且可能最好的解决方案是使用“灵活的盒子布局”。在下面的代码段中,我列出了您可以使用的示例。我建议您阅读更多关于flexbox
的内容,因为它绝对可以在以后的布局问题上再次为您提供帮助:
A Complete Guide to Flexbox on css-tricks.com
CSS Flexible Box Layout on MDN
*{
box-sizing: border-box;
margin: 0;
padding: 0;
}
.container{
display: flex;
flex-wrap: nowrap;
justify-content: center;
align-items: flex-end;
/* just for presentation */
padding: 1em;
border: 1px solid black;
}
.column--picture{
flex: 0 0 auto;
/* up to you */
width: 200px;
height: 400px;
}
.column--picture img{
/*
make sure to limit the size of the image,
or make `.column--picture` to not show
overflow content
*/
display: block;
width: 100%;
height: 100%;
object-fit: cover;
}
.column--wrapper{
flex: 0 1 auto;
/* just for presentation */
max-width: 400px;
}
.row{
/* just for presentation */
margin-left: 1em;
padding: 1em;
border: 1px solid black;
}
<div class="container">
<div class="column column--picture">
<img src="https://images.unsplash.com/photo-1458966480358-a0ac42de0a7a?ixlib=rb-0.3.5&q=80&fm=jpg&crop=entropy&cs=tinysrgb&w=1080&fit=max&ixid=eyJhcHBfaWQiOjI2ODUxfQ&s=b92b03976bc401ad70337cfd39e9ed95" alt="green leaf tree on shore">
</div>
<div class="column column--wrapper">
<div class="row">
<h2>Stop floating and start flexing.</h2>
</div>
<div class="row">
<p>Turkey beef biltong, sausage ball tip pork loin pork chop corned beef boudin ground round salami pancetta flank filet mignon sirloin.</p>
</div>
</div>
</div>
答案 3 :(得分:0)
您可以使用flexbox实现此目的。如果您尝试与旧版浏览器(例如IE 10)兼容,则此方法可能无效。 Flexbox是对齐项目的更好方法。
https://css-tricks.com/snippets/css/a-guide-to-flexbox/
.container {
display: flex;
justify-content: center;
}
.container img {
height: 180px;
}
.container .column2 {
display: flex;
flex-direction: column;
justify-content: flex-end;
}
<body>
<div class="container">
<div class="img column1">
<img
id="img"src="https://upload.wikimedia.org/wikipedia/en/5/58/Penny_test.jpg">
</div>
<div class="comment column2">
<p>a paragraph</p>
<p>another paragraph</p>
</div>
</div>
</body>
答案 4 :(得分:-1)
将此代码添加到CSS中。
.column1, .column2 {
width:300px;
margin: 10px;
display: inline-block;
vertical-align: bottom;
}
p {
margin-top: 0;
margin-bottom: 0;
}
有关解决方案,请参见this link。
答案 5 :(得分:-2)
您还可以使用rowpan和colspan功能,只需使用属性valign = bottom对齐
<!DOCTYPE html>
<html>
<head>
<style>
table, th, td {
border: 1px solid black;
}
</style>
</head>
<body>
<table>
<tr>
<th>Month</th>
<th>Savings</th>
<th>Savings for holiday!</th>
</tr>
<tr>
<td>January</td>
<td>$100</td>
<td rowspan="2" valign="bottom">$50
</td>
</tr>
<tr>
<td>February</td>
<td>$80</td>
</tr>
</table>
</body>
</html>