กริดโดยนัยใน CSS
กริดโดยนัย ถูกสร้างขึ้นโดยเบราว์เซอร์โดยอัตโนมัติ เมื่อจำนวนขององค์ประกอบไม่พอดีกับกริดที่กำหนดอย่างชัดเจน มาดูกันว่านี่เกิดขึ้นได้อย่างไร
สมมติว่าเรามีบล็อกสี่บล็อก:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
</div>
ให้กริดของเรามีขนาด
3 คูณ 3:
#parent {
display: grid;
grid-template-columns: 50px 50px 50px;
grid-template-rows: 50px 50px 50px;
}
ลองจัดวางสามบล็อกแรกของเรา ลงบนกริด:
#elem1 {
grid-row: 1 / 2;
grid-column: 1 / 2;
}
#elem2 {
grid-row: 2 / 3;
grid-column: 2 / 3;
}
#elem3 {
grid-row: 3 / 4;
grid-column: 3 / 4;
}
และให้จัดวางบล็อกที่สี่ ในแถวที่สี่และคอลัมน์ที่สี่:
#elem4 {
grid-row: 4 / 5;
grid-column: 4 / 5;
}
เนื่องจากกริดของเรามีขนาด
3 คูณ 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: 50px 50px 50px;
grid-template-rows: 50px 50px 50px;
border: 2px solid #696989;
padding: 10px;
width: 400px;
height: 400px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-row: 1 / 2;
grid-column: 1 / 2;
}
#elem2 {
grid-row: 2 / 3;
grid-column: 2 / 3;
}
#elem3 {
grid-row: 3 / 4;
grid-column: 3 / 4;
}
#elem4 {
grid-row: 4 / 5;
grid-column: 4 / 5;
}
:
สมมติว่าในกริดของคุณมีบล็อกทั้งหมด 6 บล็อก
ลองจัดวาง 3 บล็อกในกริด
ที่กำหนดชัดเจน และอีกสามบล็อกในกริดโดยนัย