上次

上次计划
1、最近文档表格完善
 2、实现登录功能
 3、新建文件,复制文件,删除文件
 4、其他
目前任务:最近文档表格完善

1、在名称前面,渲染这个文档的图标
 2、大小的基本的单位是kb,超过1024kb则换成mb,主要是这两个单位
 3、数据按照最近访问时间倒序
 4、给文件名价格链接,实现和编辑按钮相同的功能
 5、实现编辑的功能
 6、实现删除的功能
 7、分享的功能暂时往后放,因为目前没有用户,等有了用户之后再考虑做
在名称前面,渲染这个文档的图标
先实现body的插槽,对name做自定义渲染
<template #bodyCell="{ column, record }">
   <template v-if="column.key === 'action'">
     <a-space>
       <a-button>编辑</a-button>
       <a-button>删除</a-button>
       <a-button>分享</a-button>
     </a-space>
   </template>
   <template v-else-if="column.key === 'name'">
     {{ record[column.key] }}
   </template>
   <template v-else>
     {{ record[column.key] }}
   </template>
 </template>
准备svg图片资源

导入svg图片
import docxSvg from "../../assets/svg/docx.svg"
渲染svg图片
<template v-else-if="column.key === 'name'">
  <div>
    <img :src="docxSvg" alt="">
    <span>{{ record[column.key] }}</span>
  </div>
</template>
效果预览

整合Tailwindcss
参考文章:https://blog.csdn.net/qq_37703224/article/details/139401458
使用Tailwindcss优化表格
优化图标的显示
<template v-else-if="column.key === 'name'">
  <div class="flex items-center justify-center">
    <img :src="docxSvg" class="w-5 h-5 mr-1">
    <span>{{ record[column.key] }}</span>
  </div>
</template>
渲染效果:
 
图标应该根据类型动态切换思路
要实现这个功能,我们要么借助函数,要么借助计算属性。
计算属性比较适合不经常改变的数据,所以这里我们选择使用函数。
这里的图标,主要考虑五种情况:
- docx:表示文档图标
- ppt:表示PPT文件图标
- excel:表示Excel文件图标
- pdf:表示PDF文件图标
- other:其他文档图标
我们只需要准备好对应的svg图片,然后在一个函数中,通过switch进行动态捕获即可。
准备对应的svg图片

图标应该根据类型动态切换代码
导入图片:
import docxSvg from "../../assets/svg/docx.svg"
import excelSvg from "../../assets/svg/excel.svg"
import otherSvg from "../../assets/svg/other.svg"
import pdfSvg from "../../assets/svg/pdf.svg"
import pptSvg from "../../assets/svg/ppt.svg"
实现方法:
const getSvg = (typeStr) => {
  switch (typeStr) {
    case "docx":
      return docxSvg
    case "ppt":
      return pptSvg
    case "excel":
      return excelSvg
    case "pdf":
      return pdfSvg
    default:
      return otherSvg
  }
}



















