1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- <template>
- <div>
- <el-table :data="tableData" style="width: 100%; margin-bottom: 20px" row-key="id" border default-expand-all>
- <el-table-column prop="date" label="date" sortable width="180" />
- <el-table-column prop="name" label="Name" sortable width="180" />
- </el-table>
- <el-table :data="tableData1" style="width: 100%" row-key="id" border lazy :load="load" :tree-props="{ children: 'children', hasChildren: 'hasChildren' }">
- <el-table-column prop="date" label="Date" width="180" />
- <el-table-column prop="name" label="Name" width="180" />
- </el-table>
- </div>
- </template>
- <script lang="ts" setup>
- interface User {
- id: number
- date: string
- name: string
- hasChildren?: boolean
- children?: User[]
- }
- const load = (row: User, treeNode: unknown, resolve: (date: User[]) => void) => {
- setTimeout(() => {
- resolve([
- {
- id: 31,
- date: '2016-05-01',
- name: 'wangxiaohu',
- },
- {
- id: 32,
- date: '2016-05-01',
- name: 'wangxiaohu',
- },
- ])
- }, 1000)
- }
- const tableData: User[] = [
- {
- id: 1,
- date: '2016-05-02',
- name: 'wangxiaohu',
- },
- {
- id: 2,
- date: '2016-05-04',
- name: 'wangxiaohu',
- },
- {
- id: 3,
- date: '2016-05-01',
- name: 'wangxiaohu',
- children: [
- {
- id: 31,
- date: '2016-05-01',
- name: 'wangxiaohu',
- },
- {
- id: 32,
- date: '2016-05-01',
- name: 'wangxiaohu',
- },
- ],
- },
- {
- id: 4,
- date: '2016-05-03',
- name: 'wangxiaohu',
- },
- ]
- const tableData1: User[] = [
- {
- id: 1,
- date: '2016-05-02',
- name: 'wangxiaohu',
- },
- {
- id: 2,
- date: '2016-05-04',
- name: 'wangxiaohu',
- },
- {
- id: 3,
- date: '2016-05-01',
- name: 'wangxiaohu',
- hasChildren: true,
- },
- {
- id: 4,
- date: '2016-05-03',
- name: 'wangxiaohu',
- },
- ]
- </script>
|