การรวมคอลัมน์และแถวแบบผสมผสานใน CSS Grid
ลองมาดูประเภทต่างๆ ของ การรวมแถวและ คอลัมน์กัน
ตัวอย่าง
ลองสร้างตารางโดยการรวม
คุณสมบัติ grid-column
และ grid-row:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
</div>
#parent {
display: grid;
grid-template-columns: 2fr 1fr 1fr;
border: 2px solid #696989;
padding: 10px;
height: 300px;
width: 400px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-row: 1 / 3;
}
#elem2 {
grid-row: 1 / 2;
}
#elem3 {
grid-row: 1 / 2;
}
#elem4 {
grid-row: 2 / 3;
grid-column: 2 / 4;
}
:
ตัวอย่าง
และตอนนี้ลองทำให้ บล็อกที่หนึ่งและสี่ครอบคลุมทั้งแถว, และบล็อกที่สอง - สองแถวและสองคอลัมน์, และบล็อกที่สามและสี่ - หนึ่งแถว และสองคอลัมน์:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
<div id="elem5">5</div>
</div>
#parent {
display: grid;
grid-template-columns: 2fr 1fr 1fr;
border: 2px solid #696989;
padding: 10px;
height: 300px;
width: 400px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-row: 1 / 2;
grid-column: 1 / 4;
}
#elem2 {
grid-row: 2 / 4;
grid-column: 1 / 2;
}
#elem3 {
grid-row: 2 / 3;
grid-column: 2 / 4;
}
#elem4 {
grid-row: 3 / 3;
grid-column: 2 / 4;
}
#elem5 {
grid-row: 4 / 5;
grid-column: 1 / 4;
}
:
ตัวอย่าง
ลองทำให้องค์ประกอบแรก ในตารางครอบคลุมทุกคอลัมน์ในแถวแรก, และองค์ประกอบที่เหลือจัดวางในแถวที่สอง, ครอบคลุมคอลัมน์ที่มีความกว้างเท่ากัน:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
</div>
#parent {
display: grid;
grid-template-columns: 1fr 1fr 1fr;
border: 2px solid #696989;
padding: 10px;
height: 300px;
width: 400px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-row: 1 / 2;
grid-column: 1 / 4;
}
#elem2 {
grid-row: 2 / 3;
}
#elem3 {
grid-row: 2 / 3;
}
#elem4 {
grid-row: 2 / 3;
}
:
ตัวอย่าง
ลองเปลี่ยนตัวอย่างก่อนหน้า เพื่อให้องค์ประกอบที่สองครอบคลุมคอลัมน์, ที่มีความกว้างมากกว่าคอลัมน์ขององค์ประกอบ ที่สามและสี่สามเท่า:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
</div>
#parent {
height: 300px;
width: 400px;
display: grid;
grid-template-columns: 3fr 1fr 1fr;
border: 2px solid #696989;
padding: 10px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-row: 1 / 2;
grid-column: 1 / 4;
}
#elem2 {
grid-row: 2 / 3;
}
#elem3 {
grid-row: 2 / 3;
}
#elem4 {
grid-row: 2 / 3;
}
:
ตัวอย่าง
ตอนนี้ให้จัดวางสององค์ประกอบในแถวแรก, กำหนดความกว้างคอลัมน์ที่แตกต่างกันสำหรับแต่ละอัน:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
</div>
#parent {
display: grid;
grid-template-columns: repeat(4, 1fr);
border: 2px solid #696989;
padding: 10px;
height: 300px;
width: 400px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-row: 1 / 2;
grid-column: 1 / 4;
}
#elem2 {
grid-row: 1 / 2;
grid-column: 4 / 5;
}
#elem3 {
grid-row: 2 / 3;
grid-column: 1 / 3;
}
#elem4 {
grid-row: 2 / 3;
grid-column: 3 / 5;
}
:
ตัวอย่าง
สมมติว่าตอนนี้เรามีตารางที่ประกอบด้วย ห้าองค์ประกอบ ลองจัดวางองค์ประกอบแรก ในแถวบนสุด และองค์ประกอบอื่นๆ ทั้งหมด - ในแถวที่สอง:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
<div id="elem5">5</div>
</div>
#parent {
display: grid;
grid-template-columns: repeat(4, 1fr);
border: 2px solid #696989;
padding: 10px;
height: 300px;
width: 400px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-row: 1 / 2;
grid-column: 1 / 5;
}
#elem2 {
grid-row: 2 / 3;
grid-column: 1 / 2;
}
#elem3 {
grid-row: 2 / 3;
grid-column: 2 / 3;
}
#elem4 {
grid-row: 2 / 3;
grid-column: 3 / 4;
}
#elem5 {
grid-row: 2 / 3;
grid-column: 4 / 5;
}
:
แบบฝึกหัดปฏิบัติ
จัดวางองค์ประกอบทั้งหมดให้ สอดคล้องกับ ตัวอย่างต่อไปนี้:
จัดวางองค์ประกอบทั้งหมดให้ สอดคล้องกับ ตัวอย่างต่อไปนี้: