Vue实战技巧:如何展示附件(PDF、MP4、Excel、Zip等)并修改名称下载

大家好,今天给大家分享一篇关于在Vue项目中展示附件(PDF、MP4、Excel、Zip等)并修改名称下载的教程。在实际开发过程中,这个功能非常实用,下面我们就一起来学习一下。

一、准备工作

首先,确保你的项目中已经安装了Vue和相关依赖。本文以Vue 2.x版本为例进行讲解。

二、文件展示

1、获取附件列表

假设我们有一个附件列表,存储在data中:

javascript 复制代码
data() {
  return {
    fileList: [
      { name: '示例文档.pdf', url: 'http://example.com/pdf/1.pdf' },
      { name: '示例视频.mp4', url: 'http://example.com/video/1.mp4' },
      { name: '示例表格.xlsx', url: 'http://example.com/excel/1.xlsx' },
      { name: '示例压缩包.zip', url: 'http://example.com/zip/1.zip' }
    ]
  };
}

2、 展示附件列表

在模板中,我们可以使用v-for指令来遍历fileList,展示附件名称和下载按钮:

html 复制代码
<ul>
  <li v-for="(file, index) in fileList" :key="index">
    <span>{{ file.name }}</span>
    <button @click="downloadFile(file.url, file.name)">下载</button>
  </li>
</ul>

三、修改文件名并下载

1、创建下载方法

在methods中,添加一个downloadFile方法,用于修改文件名并触发下载:

javascript 复制代码
methods: {
  downloadFile(url, name) {
    // 弹出输入框,让用户输入新的文件名
    const newName = prompt('请输入新的文件名', name);
    if (newName) {
      // 创建a标签并设置下载属性
      const link = document.createElement('a');
      link.href = url;
      link.download = newName;
      document.body.appendChild(link);
      link.click();
      document.body.removeChild(link);
    }
  }
}

2、调用下载方法

在模板中的下载按钮绑定点击事件,调用downloadFile方法:

html 复制代码
<button @click="downloadFile(file.url, file.name)">下载</button>

四、总结

通过以上步骤,我们实现了在Vue项目中展示附件(PDF、MP4、Excel、Zip等)并修改名称下载的功能。这个功能在实际开发中非常实用,希望本文能对大家有所帮助。如有疑问,欢迎在评论区留言交流。

相关推荐
谷歌开发者20 分钟前
Web 开发指向标 | Chrome 开发者工具学习资源 (六)
前端·chrome·学习
一晌小贪欢26 分钟前
【Html模板】电商运营可视化大屏模板 Excel存储 + 一键导出(已上线-可预览)
前端·数据分析·html·excel·数据看板·电商大屏·大屏看板
发现你走远了26 分钟前
连接模拟器网页进行h5的调试(使用Chrome远程调试(推荐)) 保姆级图文
前端·chrome
街尾杂货店&2 小时前
css - 实现三角形 div 容器,用css画一个三角形(提供示例源码)简单粗暴几行代码搞定!
前端·css
顺凡2 小时前
删一个却少俩:Antd Tag 多节点同时消失的原因
前端·javascript·面试
小白路过2 小时前
CSS transform矩阵变换全面解析
前端·css·矩阵
爬山算法2 小时前
Redis(110)Redis的发布订阅机制如何使用?
前端·redis·bootstrap
REDcker2 小时前
前端打包工具 - Rollup 打包工具笔记
前端·笔记
前端大卫2 小时前
动态监听DOM元素高度变化
前端·javascript
Cxiaomu2 小时前
React Native App 图表绘制完整实现指南
javascript·react native·react.js