Подтвердить что ты не робот

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>
4b9b3361

Ответ 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/

Это будет работать даже в более браузерах.