เราสามารถจัดแนวองค์ประกอบหรือเนื้อหาภายในได้โดยใช้ CSS ซึ่งมีตัวเลือกต่างๆ สำหรับการจัดตำแหน่งขององค์ประกอบและเนื้อหาในแนวนอน แนวตั้ง หรือตรงกลาง
การจัดแนวในแนวนอน
- องค์ประกอบอินไลน์
องค์ประกอบแบบอินไลน์หรือองค์ประกอบแบบอินไลน์บล็อก เช่น ข้อความ สมอ สแปน ฯลฯ สามารถจัดแนวในแนวนอนได้โดยใช้คุณสมบัติ CSS text-align
- องค์ประกอบระดับบล็อก
องค์ประกอบระดับบล็อก เช่น div, p เป็นต้น สามารถจัดแนวในแนวนอนได้โดยใช้คุณสมบัติระยะขอบ CSS แต่ความกว้างขององค์ประกอบไม่ควรสัมพันธ์กับพาเรนต์ 100% เนื่องจากไม่ต้องการการจัดตำแหน่ง
- องค์ประกอบระดับบล็อกโดยใช้รูปแบบลอยตัวหรือตำแหน่ง
องค์ประกอบสามารถจัดแนวในแนวนอนด้วยความช่วยเหลือของคุณสมบัติ CSS float ซึ่งจัดองค์ประกอบหลายองค์ประกอบไปทางซ้าย/ขวาและไม่อยู่ตรงกลางหรือโดยใช้วิธีการแบบสัมบูรณ์ของโครงร่างการกำหนดตำแหน่ง CSS
ตัวอย่าง
มาดูตัวอย่างการจัดแนวนอน CSS กัน −
<!DOCTYPE html>
<html>
<head>
<title>CSS Horizontal Alignment</title>
<style>
.screen {
padding: 10px;
width: 70%;
margin: 0 auto;
background-color: #f06d06;
text-align: center;
color: white;
border-radius: 0 0 50px 50px;
border: 4px solid #000;
}
.seats span, .backSeats div{
margin: 10px;
padding: 10px;
color: white;
border: 4px solid #000;
}
.seats span{
width: 120px;
display: inline-block;
background-color: #48C9B0;
}
.left{
text-align: left;
}
.right{
text-align: right;
}
.center{
text-align: center;
}
.seats{
text-align: center;
}
.backSeats div {
background-color: #dc3545;
}
.leftFloat{
float: left;
}
.rightAbsolute{
position: absolute;
right: 150px;
}
</style>
</head>
<body>
<div class="screen">Screen</div>
<div class="seats">
<span class="left">Adam</span>
<span class="center">Martha</span>
<span class="right">Samantha</span>
<div class="backSeats">
<div class="leftFloat">Premium 1</div>
<div class="leftFloat">Premium 2</div>
<div class="rightAbsolute">Premium 3</div>
</div>
</div>
</body>
</html> ผลลัพธ์
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -

การจัดแนวแนวตั้ง
- องค์ประกอบอินไลน์
องค์ประกอบแบบอินไลน์หรือองค์ประกอบแบบอินไลน์บล็อก เช่น ข้อความ สมอ ฯลฯ สามารถจัดแนวในแนวตั้งได้ด้วยความช่วยเหลือของ CSS padding, CSS line-height หรือคุณสมบัติ CSS vertical-align
- องค์ประกอบระดับบล็อก
องค์ประกอบระดับบล็อก เช่น div, p เป็นต้น สามารถจัดแนวในแนวตั้งได้ด้วยความช่วยเหลือของคุณสมบัติระยะขอบ CSS คุณสมบัติ CSS flex พร้อมกับรายการจัดตำแหน่ง CSS หรือวิธีการกำหนดตำแหน่งแบบสัมบูรณ์ด้วยคุณสมบัติการแปลง CSS
ตัวอย่าง
มาดูตัวอย่างการจัดแนวตั้ง CSS กัน −
<!DOCTYPE html>
<html>
<head>
<title>CSS Horizontal Alignment</title>
<style>
.screen {
padding: 10px;
width: 70%;
margin: 0 auto;
background-color: #f06d06;
text-align: center;
color: white;
border-radius: 0 0 50px 50px;
border: 4px solid #000;
}
.seats span:not(.withPadding){
margin: 10px;
padding: 10px;
color: white;
border: 4px solid #000;
}
.seats span:not(.vertical){
height: 40px;
display: inline-block;
background-color: #48C9B0;
}
.withPadding{
padding: 20px 20px 0px;
height: 20px;
color: white;
border: 4px solid #000;
}
.vertical{
display: inline-table;
background-color: #48C9B0;
height: 40px;
}
.verticalText {
display: table-cell;
vertical-align: middle;
}
.withLineHeight{
line-height: 40px;
}
.seats{
text-align: center;
}
.backLeftSeat{
background-color: #dc3545;
max-height: 100px;
height: 70px;
margin: 20px;
width: 300px;
display: inline-block;
position: relative;
resize: vertical;
overflow: auto;
border: 4px solid #000;
}
.withPosition{
position: absolute;
top: 50%;
left: 2px;
right: 2px;
color: white;
padding: 20px;
transform: translateY(-50%);
}
.backRightSeats{
height: 122px;
width: 800px;
float: right;
display: inline-flex;
flex-direction: row;
justify-content: center;
align-items: center;
}
.withFlex {
background-color: #dc3545;
border: 4px solid #000;
margin-right: 10px;
color: white;
padding: 20px;
}
</style></head>
<body>
<div class="screen">Screen</div>
<div class="seats">
<span class="withPadding">Adam</span>
<span class="withLineHeight">Martha</span>
<span class="vertical"><p class="verticalText">Samantha</p></span>
<div>
<div class="backLeftSeat">
<div class="withPosition">Premium Readjustable Sofa</div>
</div>
<div class="backRightSeats">
<div class="withFlex">Premium Solo 1</div>
<div class="withFlex">Premium Solo 2</div>
<div class="withFlex">Premium Solo 3</div>
</div>
</div>
</body>
</html> ผลลัพธ์
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -
เมื่อไม่ได้ปรับ div

เมื่อ div ถูกปรับ

การจัดตำแหน่งตรงกลาง
เราสามารถจัดองค์ประกอบให้อยู่ตรงกลางด้วยวิธีการที่กล่าวถึงข้างต้นในการจัดแนวแนวนอนและแนวตั้ง