Rumah > Artikel > hujung hadapan web > Pelajari kemahiran flexbox CSS3, bagaimana untuk mencapai susunan ketinggian yang sama bagi imej halaman web?
Belajar kemahiran flexbox CSS3, bagaimana untuk mencapai susunan ketinggian yang sama bagi imej halaman web?
Dalam reka bentuk web, kita sering menghadapi situasi di mana gambar perlu disusun pada ketinggian yang sama. Kaedah tradisional adalah untuk menetapkan ketinggian tetap untuk setiap imej, tetapi ini bukan sahaja menyusahkan tetapi juga tidak fleksibel Terutamanya dalam reka bentuk responsif, ketinggian imej mungkin berbeza di bawah saiz peranti yang berbeza. Susun atur kotak flex dalam CSS3 menyediakan penyelesaian yang lebih mudah dan berkesan.
1. Pengenalan kepada flexbox
Reka letak Flexbox ialah model kotak fleksibel baharu yang ditambah dalam CSS3, yang boleh memudahkan reka letak dan penjajaran elemen halaman web. Dengan mengawal sifat kontena dan elemen kanak-kanak, reka letak halaman web yang fleksibel boleh dicapai. Dalam susun atur flexbox, bekas itu dipanggil bekas flex dan elemen kanak-kanak dipanggil item flex.
2. Reka letak Flexbox untuk mencapai susunan gambar yang sama tinggi
Berikut mengambil galeri grid ringkas sebagai contoh untuk memperkenalkan cara menggunakan susun atur flexbox untuk mencapai susunan gambar yang sama tinggi.
Struktur HTML:
<div class="grid-container"> <div class="grid-item"><img src="image1.jpg" alt=""></div> <div class="grid-item"><img src="image2.jpg" alt=""></div> <div class="grid-item"><img src="image3.jpg" alt=""></div> <div class="grid-item"><img src="image4.jpg" alt=""></div> </div>
Gaya CSS:
.grid-container { display: flex; flex-wrap: wrap; } .grid-item { flex: 1 0 200px; margin: 10px; } .grid-item img { width: 100%; height: auto; }
Mula-mula, tetapkan bekas yang mengandungi imej sebagai bekas flex, dan dayakan reka letak flexbox dengan menetapkan display: flex
. Kemudian, tetapkan flex-wrap: wrap
untuk merealisasikan pembalut baris automatik, supaya imej boleh dibalut dan dipaparkan secara automatik apabila ia melebihi lebar bekas. display: flex
来开启flexbox布局。然后,通过设置flex-wrap: wrap
来实现自动换行,让图片在超出容器宽度时自动换行显示。
接下来,将每个图片元素设置为flex item,可以使用.grid-item
类来控制。在这个例子中,我们给每个flex item设置了一个固定的宽度(200px),使用flex: 1 0 200px
来表示flex-grow属性为1(即分配剩余空间的比例),flex-shrink属性为0(即不允许缩小),flex-basis属性为200px(即初始宽度为200px)。
最后,通过设置.grid-item img
.grid-item
. Dalam contoh ini, kami menetapkan lebar tetap (200px) untuk setiap item fleksibel, menggunakan flex: 1 0 200px
untuk menunjukkan bahawa atribut flex-grow ialah 1 (iaitu, perkadaran ruang yang tinggal diperuntukkan), atribut flex-shrink ialah 0 (iaitu, pengecutan tidak dibenarkan), dan atribut flex-basis ialah 200px (iaitu, lebar awal ialah 200px). Akhir sekali, kawal gaya imej dengan menetapkan pemilih .grid-item img
Tetapkan lebar imej kepada 100% untuk menyesuaikan dengan lebar bekas induk dan tetapkan ketinggian kepada auto. untuk mengekalkan perkadaran imej Tiada herotan.
Melalui tetapan gaya di atas, gambar dalam galeri grid boleh disusun pada ketinggian yang sama. Tidak kira apa ketinggian imej, ia akan menyesuaikan secara automatik dengan ketinggian bekas dan mengekalkan paparan ketinggian yang sama.
3. Pertimbangan keserasian
Perlu diambil perhatian bahawa reka letak flexbox disokong dengan baik dalam pelbagai penyemak imbas moden, tetapi mungkin terdapat masalah keserasian dalam beberapa versi penyemak imbas yang lebih lama. Anda boleh menggunakan alatan seperti Autoprefixer untuk menjana awalan gaya secara automatik yang serasi dengan pelbagai penyemak imbas untuk memastikan paparan biasa dalam penyemak imbas yang berbeza.
Ringkasan:
Dengan mempelajari kemahiran flexbox CSS3, kita boleh mencapai susunan ketinggian yang sama bagi imej halaman web dengan mudah. Menggunakan reka letak flexbox, kita tidak perlu lagi menetapkan ketinggian tetap untuk setiap imej. Kita boleh mencapai kesan susunan ketinggian yang sama secara fleksibel di bawah saiz peranti yang berbeza dengan hanya menetapkan sifat berkaitan flexbox. 🎜🎜Saya harap pengenalan dalam artikel ini dapat membantu anda menggunakan reka letak flexbox dengan lebih baik dalam reka bentuk web dan mencapai kesan susunan imej yang lebih fleksibel dan cantik. 🎜Atas ialah kandungan terperinci Pelajari kemahiran flexbox CSS3, bagaimana untuk mencapai susunan ketinggian yang sama bagi imej halaman web?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!