CodePen:http ://codepen.io/anon/pen/RPNpaP 。
在并排视图中,我希望红色框的宽度只有25 em-我正试图通过在此媒体查询中设置CSS来实现这一点:
@media all and (min-width: 811px) {...}
至:
.flexbox .red {
width: 25em;
}
但是,当我这样做时,就会发生这种情况:
http://i.imgur.com/niFBrwt.png
知道我在做什么错吗?
CodePen:http ://codepen.io/anon/pen/RPNpaP 。
在并排视图中,我希望红色框的宽度只有25 em-我正试图通过在此媒体查询中设置CSS来实现这一点:
@media all and (min-width: 811px) {...}
至:
.flexbox .red {
width: 25em;
}
但是,当我这样做时,就会发生这种情况:
http://i.imgur.com/niFBrwt.png
知道我在做什么错吗?
Answers:
您应该使用flex
或flex-basis
属性,而不是width
。阅读有关MDN的更多信息。
.flexbox .red {
flex: 0 0 25em;
}
该flex
CSS属性是一个速记属性指定柔性项目,以改变其尺寸以填充可用空间的能力。它包含了:
flex-grow: 0; /* do not grow - initial value: 0 */
flex-shrink: 0; /* do not shrink - initial value: 1 */
flex-basis: 25em; /* width/height - initial value: auto */
一个简单的演示演示了如何将第一列设置为50px
固定宽度。
如果任何人都想要一个具有百分比(%)的响应式Flexbox,那么进行媒体查询要容易得多。
flex-basis: 25%;
测试时,这将更加平滑。
// VARIABLES
$screen-xs: 480px;
$screen-sm: 768px;
$screen-md: 992px;
$screen-lg: 1200px;
$screen-xl: 1400px;
$screen-xxl: 1600px;
// QUERIES
@media screen (max-width: $screen-lg) {
flex-basis: 25%;
}
@media screen (max-width: $screen-md) {
flex-basis: 33.33%;
}
flex-shrink
,谢谢,好的答案。