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等)并修改名称下载的功能。这个功能在实际开发中非常实用,希望本文能对大家有所帮助。如有疑问,欢迎在评论区留言交流。

相关推荐
lchcy5 分钟前
移动端h5好多兼容性问题啊
前端
KaMeidebaby10 分钟前
卡梅德生物技术快报|多肽库筛选:基于全质粒 PCR 的噬菌体文库构建与小分子表位淘选实战
前端·数据库·其他·百度·新浪微博
开始脱发的自然卷12 分钟前
用 Excel 手算一个 1-6-1 MLP:前向传播、损失、反向传播与参数更新
excel
m0_5027249513 分钟前
vue3生成pdf
前端·javascript·vue.js·pdf
@不误正业15 分钟前
2026-05-16-多Agent协作框架深度实战-从ReAct到Plan-and-Execute全架构演进
前端·react.js·架构
我命由我1234515 分钟前
PHP - PHP 简易 Web 服务器、基础接口开发
服务器·开发语言·前端·php·intellij-idea·idea·intellij idea
Reload.16 分钟前
CZ航司,shopping JS逆向 acw_sc__v2
开发语言·javascript·python·网络爬虫·ecmascript
咖喱o17 分钟前
IPv6
服务器·前端·网络
海上彼尚18 分钟前
Nodejs也能写Agent - 6.基础篇 - Agent
前端·人工智能·后端·node.js
2501_9400417421 分钟前
纯前端实战:5个高复杂度业务与交互场景
前端