Angular Material Flexbox - 如何在包裹的行之间添加边距?
Posted
技术标签:
【中文标题】Angular Material Flexbox - 如何在包裹的行之间添加边距?【英文标题】:Angular Material Flexbox - How to add margin between wrapped rows? 【发布时间】:2016-11-25 03:56:36 【问题描述】:我正在使用 Angular Material 及其 flexbox 功能。
我现在遇到了一个在我看来应该很简单的问题,但我遇到了问题。
我创建了this Codepen 来演示我的问题。
所以我有一排的项目超过该行的 100% 并且启用了换行,所以我得到两行没有边距的项目,如下所示:
<div class="row" layout="row" layout-wrap="wrap">
<div flex="50" class="item1"></div>
<div flex="50" class="item2"></div>
<div flex="50" class="item3"></div>
<div flex="50" class="item4"></div>
</div>
我正在使用这个 CSS:
.row
background-color: grey;
padding: 10px;
.item1
height: 200px;
background-color: blue;
.item2
background-color: red;
.item3
backgronud-color: black;
height: 100px;
.item4
background-color: green;
我希望它们周围的每个项目周围都有一个均匀的边距(比如说 10 像素)。
我已经尝试像平常一样设置边距,但是这些项目没有正确换行并且每行只给我一个项目。我仍然想要每行 2 个项目。
当我将子 div 添加到项目并设置 margin: 10px;
时,我成功地获得了左右边距,但顶部和底部边距被完全忽略。
那么,我怎样才能在每个包裹的行之间(垂直)以 10px 的边距包裹一行?
【问题讨论】:
【参考方案1】:您可以尝试覆盖此 Angular 指令的一部分:
flex="50" (which computes to flex: 1 1 50% [flex-grow, flex-shrink, flex-basis])
使用这个 CSS:
.row > div
flex-basis: calc(50% - 20px) !important; /* width less horizontal margins */
margin: 10px;
Revised Codepen
阅读更多关于 CSS calc
函数的信息。
【讨论】:
谢谢,这行得通!之前在 CSS 中没有见过 calc()。以上是关于Angular Material Flexbox - 如何在包裹的行之间添加边距?的主要内容,如果未能解决你的问题,请参考以下文章
Angular Material 教程之布局篇 : 布局简介
Flexbox 导致 adsense 错误:“adsbygoogle.push() 错误:没有可用宽度 = 0 的插槽大小”
Angular Material 找不到 Angular Material 核心主题
AngularCLI 和 Angular Material(原理图)错误:无法解析集合“@angular/material”