วิธีสร้างตารางเลื่อนจากแท็ก Div โดยใช้ CSS โดยไม่มีแท็กตาราง

จะใช้คุณสมบัติ 'แสดง' เพื่อแสดงตารางได้อย่างไร

ตารางด้านล่างแสดงความสัมพันธ์ระหว่างแท็ก ' ตาราง ' และพร็อพเพอร์ตี้ CSS ที่สนับสนุนซึ่งสอดคล้องกันเพื่อแสดงองค์ประกอบเดียวกัน ดังนั้น เมื่อสร้างตาราง สิ่งที่คุณต้องทำคือ แทนที่จะใช้แท็ก HTML ' table ' เพียงใช้แท็ก ' div ' และเพิ่ม CSS ที่เกี่ยวข้องเพื่อแสดงตาราง

<ตาราง> {จอแสดงผล:ตาราง}
<tr> {แสดง: ตาราง-แถว}
<ส่วนหัว> {จอแสดงผล: table-header-group}
<tbody> {จอแสดงผล: ตาราง-แถว-กลุ่ม}
<เท้า> {จอแสดงผล: กลุ่มส่วนท้ายของตาราง}
<col> {จอแสดงผล: ตาราง-คอลัมน์}
<คอลกรุ๊ป> {จอแสดงผล: ตาราง-คอลัมน์-กลุ่ม}
<td>, <th> {จอแสดงผล: ตารางเซลล์}
<คำบรรยายภาพ> {จอแสดงผล: ตารางคำบรรยาย}

ขั้นตอนที่ 1: สร้าง Div หลักสำหรับตาราง

HTML

<div class="d-tbl"></div>

ซีเอสเอส

.d-tbl {  
    width: 100%;  
    display: table;  
    border-collapse: collapse;  
}

ขั้นตอนที่ 3: สร้างคำอธิบายตาราง, ส่วนหัว, เนื้อหา, ส่วนท้าย

HTML

<div class="d-tbl">  
    <div class="d-tbl-head"></div>  
    <div class="d-tbl-body">/div>  
    <div class="d-tbl-foot"></div>  
</div>

ซีเอสเอส

.d-tbl-caption{  
    display: table-caption;  
    text-align: center;  
    font-weight: bold;  
}  
.d-tbl-head,  
.d-tbl-foot {  
    display: table-header-group;  
    background-color: white;  
}  
.d-tbl-body {  
    display: table-row-group;  
}

ขั้นตอนที่ 3: สร้างแถวตาราง เซลล์ เซลล์ส่วนหัว เซลล์เท้า

HTML

<div class="d-tbl">  
    <div class="d-tbl-head">  
        <div class="d-tbl-row">  
            <div class="d-tbl-cell d-tbl-head-cell">Header 1</div>  
            <div class="d-tbl-cell d-tbl-head-cell">Header 2</div>  
            <div class="d-tbl-cell d-tbl-head-cell">Header 3</div>  
            <div class="d-tbl-cell d-tbl-head-cell">Header 4</div>  
        </div>  
    </div>  
    <div class="d-tbl-body">  
        <div class="d-tbl-row">  
            <div class="d-tbl-cell">Column 1</div>  
            <div class="d-tbl-cell">Column 2</div>  
            <div class="d-tbl-cell">Column 3</div>  
            <div class="d-tbl-cell">Column 4</div>  
        </div>  
    </div>  
    <div class="d-tbl-foot">  
        <div class="d-tbl-row">  
            <div class="d-tbl-cell d-tbl-head-foot">Footer 1</div>  
            <div class="d-tbl-cell d-tbl-head-foot">Footer 2</div>  
            <div class="d-tbl-cell d-tbl-head-foot">Footer 3</div>  
            <div class="d-tbl-cell d-tbl-head-foot">Footer 4</div>  
        </div>  
    </div>  
</div>

ซีเอสเอส

.d-tbl-row {  
    display: table-row;  
}  
.d-tbl-cell {  
    display: table-cell;  
    padding: 5px;  
    border: 1px solid #dee2e6;  
}  
.d-tbl-head-cell,  
.d-tbl-foot-cell {  
    font-weight: bold;  
}

ผลลัพธ์

css div ไปยังตาราง

ขั้นตอนที่ 4: เพิ่มแถบเลื่อนลงในตาราง

HTML

<div class="p_fix_table">  
    <div class="d-tbl">  
        <div class="d-tbl-head" id="d-tbl-fix-head"></div>  
        <div class="d-tbl-body" id="d-tbl-fix-body" onscroll="tblFixScroll('d-tbl-fix-head', 'd-tbl-fix-body')"></div>  
    </div>  
</div>

ซีเอสเอส

.p_fix_table {  
    width: 100%;  
    max-height: 250px;  
    overflow: hidden;  
}  
.p_fix_table .d-tbl {  
    display: flex;  
    flex-direction: column;  
    flex: 1 1 auto;  
    width: 100%;  
    max-height: 250px;  
    border: 1px solid #dee2e6;  
    border-collapse: collapse;  
    overflow: hidden;  
}  
.p_fix_table .d-tbl-head {  
    flex: 1 0 auto;  
    display: block;  
    overflow-x: hidden;  
    overflow-y: scroll;  
    scrollbar-base-color: #dee2e6;  
    scrollbar-face-color: #dee2e6;  
    scrollbar-highlight-color: #dee2e6;  
    scrollbar-track-color: #dee2e6;  
    scrollbar-arrow-color: #dee2e6;  
    scrollbar-shadow-color: #dee2e6;  
}  
.p_fix_table .d-tbl-head::-webkit-scrollbar {  
    display: block;  
    background-color: transparent;  
}  
.p_fix_table .d-tbl-head::-webkit-scrollbar-track {  
    background-color: transparent;  
}  
.p_fix_table .d-tbl-body {  
    display: block;  
    overflow: scroll;  
    max-height: 220px;  
}  
.p_fix_table .d-tbl-body:nth-child(3) {  
    display: none;  
}  
.p_fix_table .d-tbl-cell,  
.p_fix_table .d-tbl-head-cell {  
    width: 170px;  
    min-width: 170px;  
    padding: 5px;  
    border: 1px solid #dee2e6;  
}  
.p_fix_table .d-tbl-row .d-tbl-cell:first-child,  
.p_fix_table .d-tbl-row .d-tbl-head-cell:first-child {  
    position: sticky;  
    left:0;  
    background: white;  
    z-index: 1;  
}

จส

function tblFixScroll(thead_id, tbody_id) {  
    let thead = document.getElementById(thead_id);  
    let tbodyScroll = document.getElementById(tbody_id).scrollLeft;  
    thead.scrollLeft = tbodyScroll;  
    //document.getElementById("frozen").scrollLeft = 0;  
}