이 기사에서는 경량 JavaScript 프레임워크인 Alpine JS를 사용하여 동적 테이블을 만드는 방법을 살펴봅니다. 기본 시나리오와 복잡한 시나리오에 초점을 맞춰 프로세스를 머리글, 본문, 바닥글의 세 부분으로 나누어 보겠습니다.
초기 코드는 아래와 같습니다.
<div x-data="data"> </div> <script> let data = { } </script>
<thead class="sticky top-0 z-10 text-gray-700 bg-gray-50 dark:bg-gray-700 dark:text-gray-400"> <template x-for="row in table.customHeader"> <tr> <template x-for="col in row"> <th class="px-4 font-semibold text-left border-b py-1.5" x-init="col.attr && Object.keys(col.attr).forEach(e => $el.setAttribute(e, col.attr[e]))"> <div class="flex items-center justify-center"> <span x-html="col.title" class="whitespace-nowrap"></span> </div> </th> </template> </tr> </template> </thead>
let data = { table: { customHeader: [ [ { title: 'City', attr: { rowspan: 2 }, class: 'border-r border-t' }, { title: 'Clothes', attr: { colspan: 3 }, class: 'border-r border-t' }, { title: 'Accessories', attr: { colspan: 2 }, class: 'border-t' } ], [ { title: 'Trousers', class: 'border-r' }, { title: 'Skirts', class: 'border-r' }, { title: 'Dresses', class: 'border-r' }, { title: 'Bracelets', class: 'border-r' }, { title: 'Rings' }, ] ], } }
<tbody> <template x-for="(row, idx) in table.data"> <tr class="border-b dark:border-gray-700"> <template x-for="(col, icol) in row.columns"> <td x-bind:class="{ [col.class]: !!col.class }" class="px-3 border-b border-gray-200"> <div x-text="col.text"></div> </td> </template> </tr> </template> </tbody>
그리고 이것이 우리가 보여주고 싶은 데이터입니다:
data: [ { "city": "Mandalay", "trousers": 79, "skirts": 16, "dresses": 14, "bracelets": 69, "rings": 99 }, { "city": "George Town", "trousers": 68, "skirts": 24, "dresses": 90, "bracelets": 96, "rings": 48 }, { "city": "Gent", "trousers": 26, "skirts": 60, "dresses": 67, "bracelets": 5, "rings": 43 }, { "city": "Mombasa", "trousers": 34, "skirts": 62, "dresses": 18, "bracelets": 75, "rings": 78 }, { "city": "Lyon", "trousers": 13, "skirts": 33, "dresses": 12, "bracelets": 0, "rings": 17 }, { "city": "Vancouver", "trousers": 82, "skirts": 91, "dresses": 18, "bracelets": 96, "rings": 72 }, { "city": "Cairn", "trousers": 64, "skirts": 43, "dresses": 14, "bracelets": 95, "rings": 55 }, ]
<tfoot class="sticky bg-gray-100 -bottom-1"> <template x-for="row in table.customFooter"> <tr> <template x-for="col in row"> <td class="px-3 border-b border-gray-200" x-init="col.attr && Object.keys(col.attr).forEach(e => $el.setAttribute(e, col.attr[e]))"> <div x-html="table.footerData[col.name)"> </div> </td> </template> </tr> </template> </tfoot>
customFooter: [ [ { value: 'Total', class: 'font-bold border-r text-center', attr: { rowspan: 2 } }, { name: 'total-trousers', class: 'text-right border-r' }, { name: 'total-skirts', class: 'text-right border-r', }, { name: 'total-dresses', class: 'text-right border-r' }, { name: 'total-bracelets', class: 'text-right border-r' }, { name: 'total-rings', class: 'text-right' }, ], [ { name: 'total-clothes', class: 'text-center border-r', attr: { colspan: 3 } }, { name: 'total-accessories', class: 'text-center', attr: { colspan: 2 } }, ], ],
도시 이름과 다양한 의류 품목이 포함된 샘플 데이터로 테이블의 기능을 시연합니다.
이 분석에서는 Alpine JS를 통해 유연한 머리글, 본문, 바닥글이 포함된 동적 테이블을 만들 수 있는 방법을 보여줍니다. 이 접근 방식은 특히 데이터가 자주 변경되는 시나리오의 경우 테이블 생성 및 관리를 단순화합니다.
위 내용은 Alpine JS를 사용한 동적 테이블 생성의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!