flex-item
をクリックすると、その下の完全な行のサイズに拡張する必要があるような機能を追加したいとします。基本的にはクリックするとサイズが大きくなり、もう一度クリックすると元のサイズに戻ります。ボタンのクリックでフレックスアイテムのサイズを大きくする
次のelements
は、同じサイズのままでなければならず、展開された後に次の行に移動する必要があります。flex-item
と同じプロパティflex-box
に従います。 flex-items
はクリック時に展開され、別のクリックで同じサイズに戻ることができるクリック可能なelements
でなければなりません。
私はこれを理解することができず、私はフロントエンドの技術に慣れていません。
$('#clickMe').click(function() {
$('#Demosss').append($('<li id="flx-item" class="flex-item">').text('dar'));
$(this).insertAfter($('[class^="flex-item"]').last());
});
.flex-container {
padding: 0;
margin: 0;
list-style: none;
-webkit-flex-direction: row; /* Safari */
flex-direction: row;
flex-wrap: wrap;
}
.flex-item {
background: tomato;
padding: 5px;
width: 200px;
height: 150px;
margin-top: 10px;
margin-right: 15px;
line-height: 150px;
color: white;
font-weight: bold;
font-size: 3em;
text-align: center;
display: inline-block;
}
ul li{
display: inline;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<ul id="Demosss" class="flex-container">
<!-- add LI here -->
</ul>
<button id="clickMe">Click Me</button>
'$(この).toggleClass( '拡張');' $(とあなたはすでに 'expand'クラスを削除する場合'意味をなさない '拡大'。 ).removeClass( 'expand'); '、少なくとも投稿する前にあなたの答えをチェックしてください。 –
あなたは@TalentRunnersが間違っていると思います。あなたはそれを削除しようとした後、効果を見ましたか?そのコード行を削除すると、複数のフレックス項目を同時に展開することができます。このコードを使用すると、一度に1つのフレックスアイテムのみを展開することができます。つまり、私の答えは、OPがどのシナリオを望んでいたかを特定していないので、この柔軟性を可能にしています。 – Noel