vertical-list.vue 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. <template>
  2. <el-radio-group v-model="size">
  3. <el-radio label="large">Large</el-radio>
  4. <el-radio>Default</el-radio>
  5. <el-radio label="small">Small</el-radio>
  6. </el-radio-group>
  7. <el-descriptions title="Vertical list with border" direction="vertical" :column="4" :size="size" border>
  8. <el-descriptions-item label="Username">kooriookami</el-descriptions-item>
  9. <el-descriptions-item label="Telephone">18100000000</el-descriptions-item>
  10. <el-descriptions-item label="Place" :span="2">Suzhou</el-descriptions-item>
  11. <el-descriptions-item label="Remarks">
  12. <el-tag size="small">School</el-tag>
  13. </el-descriptions-item>
  14. <el-descriptions-item label="Address">No.1188, Wuzhong Avenue, Wuzhong District, Suzhou, Jiangsu Province </el-descriptions-item>
  15. </el-descriptions>
  16. <el-descriptions title="Vertical list without border" :column="4" :size="size" direction="vertical" :style="blockMargin">
  17. <el-descriptions-item label="Username">kooriookami</el-descriptions-item>
  18. <el-descriptions-item label="Telephone">18100000000</el-descriptions-item>
  19. <el-descriptions-item label="Place" :span="2">Suzhou</el-descriptions-item>
  20. <el-descriptions-item label="Remarks">
  21. <el-tag size="small">School</el-tag>
  22. </el-descriptions-item>
  23. <el-descriptions-item label="Address">No.1188, Wuzhong Avenue, Wuzhong District, Suzhou, Jiangsu Province </el-descriptions-item>
  24. </el-descriptions>
  25. </template>
  26. <script setup lang="ts">
  27. import { computed, ref } from 'vue'
  28. const size = ref('')
  29. const blockMargin = computed(() => {
  30. const marginMap = {
  31. large: '32px',
  32. default: '28px',
  33. small: '24px',
  34. }
  35. return {
  36. marginTop: marginMap[size.value] || marginMap.default,
  37. }
  38. })
  39. </script>
  40. <style scoped>
  41. .el-descriptions {
  42. margin-top: 20px;
  43. }
  44. </style>