Анимация сетки Flexbox с помощью Flexbox - PullRequest
0 голосов
/ 31 октября 2018

У меня есть сетка с Flexbox.

html, body {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    overflow: hidden;    
}

.container {
    display: flex;
    height: 100%;
    flex-wrap: wrap;
}

.item {
    width: 49%;
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: auto;
    transition: all .2s;
}

.item:hover {
    flex-grow: 1.2;
}
<div class="container">
    <div class="item" style="background: red">a</div>
    <div class="item" style="background: green">b</div>
    <div class="item" style="background: blue">c</div>
    <div class="item" style="background: purple">d</div>
</div>

Я хочу анимировать элементы при наведении: один под курсором увеличивается по ширине и высоте, а остальные растягиваются соответственно. Мне удалось сделать это, только если применить flex-direction: column;, но тогда это уже не сетка:

html, body {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    overflow: hidden;    
}

.container {
    display: flex;
    flex-direction: column;
    height: 100%;
    flex-wrap: wrap;
}

.item {
    width: 49%;
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: auto;
    transition: all .2s;
}

.item:hover {
    flex-grow: 1.2;
}
<div class="container">
    <div class="item" style="background: red">a</div>
    <div class="item" style="background: green">b</div>
    <div class="item" style="background: blue">c</div>
    <div class="item" style="background: purple">d</div>
</div>

Как я могу это сделать?

Ответы [ 2 ]

0 голосов
/ 31 октября 2018

Уменьшите ширину по умолчанию. Если вы оставите значение больше 33,3%, только 2 элемента разделят строку

Добавлено изменение высоты

html, body {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    overflow: hidden;    
}

.container {
    display: flex;
    height: 100%;
    flex-wrap: wrap;
}

.item {
    width: 35%;   /* can not go under 33% */
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: auto;
    transition: all .2s;
}

.item:hover {
    flex-grow: 22;
    min-height: 50%;
}
.container:hover .item:not(:hover) {
    flex-grow: 1;
}
<div class="container">
    <div class="item" style="background: red">a</div>
    <div class="item" style="background: green">b</div>
    <div class="item" style="background: blue">c</div>
    <div class="item" style="background: purple">d</div>
</div>
0 голосов
/ 31 октября 2018

Flex растут / сжимаются не работают, если у вас установлен явный рост / ширина. Ваша flex-column версия работает, потому что у вас не установлена ​​высота. Удалите .item{width:49%;}, и горизонтальная версия тоже работает.

Если вы хотите, чтобы он был упакован, используйте flex-wrap и flex-basis:50%, но это будет делать странные вещи, если они растут / уменьшаются.

html, body {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    overflow: hidden;    
}

.container {
    display: flex;
    flex-direction: column;
    height: 100%;
    flex-wrap: wrap;
}

.item {
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: auto;
    transition: all .2s;
}

.item:hover {
    flex-grow: 1.2;
}
<div class="container">
    <div class="item" style="background: red">a</div>
    <div class="item" style="background: green">b</div>
    <div class="item" style="background: blue">c</div>
    <div class="item" style="background: purple">d</div>
</div>
...