在 Vue 项目中,要实现文件下载功能,通常有几种方式可以选择。
1. 直接使用 `a` 标签的 `download` 属性:
```html
点击下载
```
这种方式能够直接触发文件下载,但需要确保 `/path/to/file` 对应的文件可以在服务器上被访问到。
2. 使用 `axios` 发送 GET 请求,并将响应数据保存为文件:
```js
import axios from 'axios';
async function downloadFile() {
const response = await axios.get('/path/to/file'
{
responseType: 'blob' // 设置响应数据类型为二进制
});
const blob = new Blob([response.data]);
const link = document.createElement('a');
link.href = window.URL.createObjectURL(blob);
link.download = 'filename'; // 设置下载的文件名称
link.click();
window.URL.revokeObjectURL(link.href);
}
export default {
methods: {
async handleDownload() {
try {
await downloadFile();
} catch (error) {
console.error('下载文件失败'
error);
}
}
}
}
```
上述代码通过 `axios` 来发送 GET 请求并获取响应数据,将数据封装成 `Blob` 实例,并通过动态创建 `a` 标签的方式进行下载。
3. 使用第三方库 `file-saver` 来实现文件下载:
```bash
npm install file-saver --save
```
```js
import axios from 'axios';
import { saveAs } from 'file-saver';
async function downloadFile() {
const response = await axios.get('/path/to/file'
{
responseType: 'blob'
});
saveAs(response.data
'filename');
}
export default {
methods: {
async handleDownload() {
try {
await downloadFile();
} catch (error) {
console.error('下载文件失败'
error);
}
}
}
}
```
上述代码使用了 `file-saver` 库的 `saveAs` 方法,通过传入响应数据和文件名称来实现文件下载。