custom-header.vue 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. <template>
  2. <el-table :data="filterTableData" style="width: 100%">
  3. <el-table-column label="Date" prop="date" />
  4. <el-table-column label="Name" prop="name" />
  5. <el-table-column align="right">
  6. <template #header>
  7. <el-input v-model="search" size="small" placeholder="Type to search" />
  8. </template>
  9. <template #default="scope">
  10. <el-button size="small" @click="handleEdit(scope.$index, scope.row)">Edit</el-button>
  11. <el-button size="small" type="danger" @click="handleDelete(scope.$index, scope.row)">Delete</el-button>
  12. </template>
  13. </el-table-column>
  14. </el-table>
  15. </template>
  16. <script lang="ts" setup>
  17. import { computed, ref } from 'vue'
  18. interface User {
  19. date: string
  20. name: string
  21. address: string
  22. }
  23. const search = ref('')
  24. const filterTableData = computed(() => tableData.filter(data => !search.value || data.name.toLowerCase().includes(search.value.toLowerCase())))
  25. const handleEdit = (index: number, row: User) => {
  26. console.log(index, row)
  27. }
  28. const handleDelete = (index: number, row: User) => {
  29. console.log(index, row)
  30. }
  31. const tableData: User[] = [
  32. {
  33. date: '2016-05-03',
  34. name: 'Tom',
  35. address: 'No. 189, Grove St, Los Angeles',
  36. },
  37. {
  38. date: '2016-05-02',
  39. name: 'John',
  40. address: 'No. 189, Grove St, Los Angeles',
  41. },
  42. {
  43. date: '2016-05-04',
  44. name: 'Morgan',
  45. address: 'No. 189, Grove St, Los Angeles',
  46. },
  47. {
  48. date: '2016-05-01',
  49. name: 'Jessy',
  50. address: 'No. 189, Grove St, Los Angeles',
  51. },
  52. ]
  53. </script>