新学flex布局,怎么用flex实现这种布局
思路:
父级使用flex
,子元素会像inline
元素一样在一行显示,当然flex-direction
为默认情况,当flex-direction
设置为column
时会上下排列。
所以分为左右两边left和right,test使用display: flex;
至于flex-direction
和flex: 1
等更多flex
用法自己去看资料学习
<div class="test">
<div class="left">
<div class="a-wrapper">
<div class="test-item a"></div>
</div>
<div class="test-item b"></div>
</div>
<div class="right">
<div class="test-item c"></div>
</div>
</div>
.test {
display: flex;
width: 600px;
height: 400px;
}
.test .test-item {
width: 200px;
height: 40px;
}
.a {
background-color: #000;
}
.b {
background-color: #f00;
}
.c {
background-color: #ff0;
}
.left, .right {
display: flex;
flex-direction: column;
}
.left .a-wrapper {
flex: 1;
}
.right {
flex: 1;
align-items: flex-end;
}
<style type="text/css">
.flex-row {display:-webkit-flex;display:flex;-webkit-flex-direction:row;flex-direction:row;}
.flex-row > .flex-main {-webkit-flex:1 1 auto;flex:1 1 auto;}
.flex-row > .flex-side {-webkit-flex:0 0 auto;flex:0 0 auto;}
.flex-column {display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;}
.flex-column > .flex-main {-webkit-flex:1 1 auto;flex:1 1 auto;}
.flex-column > .flex-side {-webkit-flex:0 0 auto;flex:0 0 auto;}
.cell {min-width:10em;}
</style>
<div class="flex-column">
<div class="flex-side flex-row">
<div class="flex-side cell" style="background-color:blue"></div>
<div class="flex-main"></div>
<div class="flex-side"></div>
</div>
<div class="flex-main">
</div>
<div class="flex-side flex-row">
<div class="flex-side cell" style="background-color:green"> </div>
<div class="flex-main"></div>
<div class="flex-side cell" style="background-color:red"> </div>
</div>
</div>
13 回答12.9k 阅读
7 回答2.1k 阅读
3 回答1.3k 阅读✓ 已解决
2 回答1.3k 阅读✓ 已解决
6 回答1.2k 阅读✓ 已解决
2 回答904 阅读✓ 已解决
3 回答774 阅读✓ 已解决
可以参考阮一峰老师的 flex 教程( http://www.ruanyifeng.com/blo... )。
图中这种布局类似这篇博文里实现的点数为 4 的骰子。