CSS Flexbox issue: Почему ширина моих гибких детей зависит от их содержимого?
Каждому ребенку моего flexbox присваивается стиль box-flex: 1
. Я понимаю, что их ширина должна быть равна друг другу (оба занимают 50% от общей ширины их родительского flexbox). Но когда контент добавляется к детям, их ширина изменяется (в зависимости от содержимого и заполнения)! Почему это происходит?
CSS:
.hasFlex {
display: box;
display: -webkit-box;
display: -moz-box;
-webkit-box-align: start;
-moz-box-align: start;
box-align: start;}
.box0 {
-webkit-box-flex: 0;
-moz-box-flex: 0;
box-flex: 0;}
.box1 {
-webkit-box-flex: 1;
-moz-box-flex: 1;
box-flex: 1;}
.box2 {
-webkit-box-flex: 2;
-moz-box-flex: 2;
box-flex: 2;}
.box3 {
-webkit-box-flex: 3;
-moz-box-flex: 3;
box-flex: 3;}
.container {
margin-bottom: 10px;
}
HTML:
<div class="container hasFlex">
<div id="main" role="main" class="box1">
<div class="innerBG">
a bunch of stuff (divs, text, etc) go here
</div>
</div>
<div id="sidebar" class="box1">
<div class="innerBG">
a bunch more stuff (divs, text, etc.) go here
</div>
</div>
</div>
Ответы
Ответ 1
Обходной путь для этого - добавить width: 0
к элементам .box1
.
Смотрите: http://jsfiddle.net/thirtydot/fPfvN/
Думаю, я нашел это для себя здесь: http://oli.jp/2011/css3-flexbox/
Предпочтительная ширина дочернего элемента элемента, содержащего текстовое содержимое, в настоящее время текст без разрывов строк, что приводит к очень неинтуитивным ширина и гибкость вычислений → объявить ширину на дочернем элементе окна с более чем несколькими словами (когда-либо задумывались, почему flexbox демо все "1,2,3"?)
Обратите внимание, что для вашей ситуации гораздо проще использовать display: table
+ table-layout: fixed
: http://jsfiddle.net/thirtydot/fPfvN/1/
Это будет работать даже в более браузерах.