flex-basis
CSS
property sets the initial main size of a flex item. It sets the size of the content box unless otherwise set with
box-sizing
.
The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone https://github.com/mdn/interactive-examples and send us a pull request.
注意:
in case both
flex-basis
(other than
auto
) and
width
(或
height
in case of
flex-direction: column
) are set for an element,
flex-basis
has priority.
/* Specify <'width'> */ flex-basis: 10em; flex-basis: 3px; flex-basis: auto; /* Intrinsic sizing keywords */ flex-basis: fill; flex-basis: max-content; flex-basis: min-content; flex-basis: fit-content; /* Automatically size based on the flex item’s content */ flex-basis: content; /* Global values */ flex-basis: inherit; flex-basis: initial; flex-basis: unset;
flex-basis
property is specified as either the keyword
content
或
<'width'>
.
<'width'>
<length>
,
<percentage>
of the parent flex container's main size property, or the keyword
auto
. Negative values are invalid. Defaults to
auto
.
content
Indicates automatic sizing, based on the flex item’s content.
auto
together with a main size (
width
or
height
) of
auto
.
History:
flex-basis:auto
meant "look at my
width
or
height
property".
flex-basis:auto
was changed to mean automatic sizing, and "main-size" was introduced as the "look at my
width
or
height
property" keyword. It was implemented in
bug 1032922
.
auto
once again means "look at my
width
or
height
property"; and a new
content
keyword is being introduced to trigger automatic sizing. (
bug 1105111
covers adding that keyword).
| 初始值 |
auto
|
|---|---|
| 适用于 | flex items, including in-flow pseudo-elements |
| 继承 | no |
| 百分比 | refer to the flex container's inner main size |
| 计算值 | as specified, but with relative lengths converted into absolute lengths |
| 动画类型 | a length , percentage or calc(); |
content | <'width'>
<ul class="container"> <li class="flex flex1">1: flex-basis test</li> <li class="flex flex2">2: flex-basis test</li> <li class="flex flex3">3: flex-basis test</li> <li class="flex flex4">4: flex-basis test</li> <li class="flex flex5">5: flex-basis test</li> </ul> <ul class="container"> <li class="flex flex6">6: flex-basis test</li> </ul>
.container {
font-family: arial, sans-serif;
margin: 0;
padding: 0;
list-style-type: none;
display: flex;
flex-wrap: wrap;
}
.flex {
background: #6AB6D8;
padding: 10px;
margin-bottom: 50px;
border: 3px solid #2E86BB;
color: white;
font-size: 14px;
text-align: center;
position: relative;
}
.flex:after {
position: absolute;
z-index: 1;
left: 0;
top: 100%;
margin-top: 10px;
width: 100%;
color: #333;
font-size: 12px;
}
.flex1 {
flex-basis: auto;
}
.flex1:after {
content: 'auto';
}
.flex2 {
flex-basis: max-content;
}
.flex2:after {
content: 'max-content';
}
.flex3 {
flex-basis: min-content;
}
.flex3:after {
content: 'min-content';
}
.flex4 {
flex-basis: fit-content;
}
.flex4:after {
content: 'fit-content';
}
.flex5 {
flex-basis: content;
}
.flex5:after {
content: 'content';
}
.flex6 {
flex-basis: fill;
}
.flex6:after {
content: 'fill';
}
| 规范 | 状态 | 注释 |
|---|---|---|
|
CSS Flexible Box Layout Module
The definition of 'flex-basis' in that specification. |
候选推荐 | 初始定义 |
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
flex-basis
|
Chrome 完整支持 29 | Edge 完整支持 12 |
Firefox
完整支持
22
注意事项
|
IE
完整支持
11
注意事项
|
Opera 完整支持 12.1 | Safari 完整支持 9 | WebView Android 完整支持 4.4 | Chrome Android 完整支持 29 |
Firefox Android
完整支持
22
注意事项
|
Opera Android 完整支持 12.1 | Safari iOS 完整支持 9 | Samsung Internet Android 完整支持 2.0 |
auto
|
Chrome 完整支持 22 | Edge 完整支持 12 | Firefox 完整支持 18 | IE 完整支持 11 | Opera 完整支持 12.1 | Safari 完整支持 9 | WebView Android 完整支持 ≤37 | Chrome Android 完整支持 25 | Firefox Android 完整支持 18 | Opera Android 完整支持 12.1 | Safari iOS 完整支持 9 | Samsung Internet Android 完整支持 1.5 |
content
|
Chrome 不支持 No | Edge 不支持 12 — 79 | Firefox 完整支持 61 | IE 不支持 No | Opera 不支持 No | Safari 不支持 No | WebView Android 不支持 No | Chrome Android 不支持 No | Firefox Android 完整支持 61 | Opera Android 不支持 No | Safari iOS 不支持 No | Samsung Internet Android 不支持 No |
max-content
|
Chrome 不支持 No | Edge 不支持 No |
Firefox
完整支持
66
|
IE 不支持 No | Opera 不支持 No | Safari 不支持 No | WebView Android 不支持 No | Chrome Android 不支持 No |
Firefox Android
完整支持
66
|
Opera Android 不支持 No | Safari iOS 不支持 No | Samsung Internet Android 不支持 No |
min-content
|
Chrome 不支持 No | Edge 不支持 No |
Firefox
完整支持
66
|
IE 不支持 No | Opera 不支持 No | Safari 不支持 No | WebView Android 不支持 No | Chrome Android 不支持 No |
Firefox Android
完整支持
66
|
Opera Android 不支持 No | Safari iOS 不支持 No | Samsung Internet Android 不支持 No |
完整支持
不支持
见实现注意事项。
用户必须明确启用此特征。
要求使用供应商前缀或不同名称。
width
flex
flex-basis
flex-direction
flex-flow
flex-grow
flex-shrink
flex-wrap
order