我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue中点击url下载文件的案例详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue中点击url下载文件的案例详解

  • 封装自定义指令
  • 将url转成bold,在创建a标签下载blob

代码实现

在class="lazy" data-src 下面的 directive 文件夹下新建目录 downLoadUrl

downLoadUrl / index.js文件


 
import downLoad from './downLoad'
 
const install = function(Vue) {
  Vue.directive('downLoadUrl', downLoad)
}
 
downLoad.install = install
 
export default downLoad

downLoadUrl / downLoad.js文件

export default {
    bind(el, binding) {
        if (binding.value.url) {
            el.addEventListener('click', () => {
                const a = document.createElement('a')
                //   let url = baseUrl + binding.value // 若是不完整的url则需要拼接baseURL
                const url = binding.value.url // 完整的url则直接使用
                // 这里是将url转成blob地址,
                fetch(url).then(res => res.blob()).then(blob => { // 将链接地址字符内容转变成blob地址
                    a.href = URL.createObjectURL(blob)
                    console.log(a.href)
                    a.download = binding.value.name || '' // 下载文件的名字
                    // a.download = url.split('/')[url.split('/').length -1] //  // 下载文件的名字
                    document.body.appendChild(a)
                    a.click()
                    
                    //在资源下载完成后 清除 占用的缓存资源
                    window.URL.revokeObjectURL(a.href);
                    document.body.removeChild(a);
                })
            })
        }
    }
}

在main.js注册自定义指令

使用

返回一个对象{ url: '', name: ''}

注意

1、若是文件的url存在跨域的情况,则可能会下载失败,因为fetch请求连接后,由于跨域,拿不到资源,也就无法执行后续的操作,此时是失败的。

2、也可以设置浏览器,对于一下像pdf,图片等资源不直接打开,直接下载,然后简单的创建a标签下载即可。

到此这篇关于Vue中点击url下载文件-案例的文章就介绍到这了,更多相关vue点击url下载文件内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vue中点击url下载文件的案例详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

windows8中IE10无法下载文件(点击下载链接无反应)的解决方法

从Windows 7以升级的方式安装Windows 8后,发现使用IE10出现无法下载文件的问题。点击网页的中下载链接IE10没有任何反应。然后单击界面右上角的“工具”——“下载管
2022-06-04

Android中DownloadManager实现文件下载实例详解

Android中DownloadManager实现文件下载 下载 创建下载链接DownloadManager.Request request = new DownloadManager.Request(Uri.parse(url)); 设置
2022-06-06

vue中@click绑定事件点击不生效的原因及解决方案

根据Vue2.0官方文档关于父子组件通讯的原则,父组件通过prop传递数据给子组件,子组件触发事件给父组件,这篇文章主要介绍了vue中@click绑定事件点击不生效的解决方案,需要的朋友可以参考下
2022-12-08

组件库中使用vue-i18n国际化的案例详解

这篇文章主要介绍了组件库中使用vue-i18n国际化,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-18

Java 从网上下载文件的几种方式实例代码详解

废话不多说了,直接给大家贴代码了,具体代码如下所示;package com.github.pandafang.tool;import java.io.BufferedOutputStream;import java.io.File;impo
2023-05-31

javascript浏览器的停止按钮被按下时触发此事件或者正在下载的文件被中断使用什么函数,详细讲解

当用户点击浏览器停止按钮或中断文件下载时,JavaScript会触发特定事件。停止按钮事件(window.onbeforeunload)允许开发者:询问用户是否离开页面保存未保存的数据返回字符串提示用户确认停止操作文件下载中断事件(XMLHttpRequest.onabort)允许开发者:显示下载中断消息重新启动下载事件处理最佳实践包括:用户确认数据保存错误处理轻量级操作一致性
javascript浏览器的停止按钮被按下时触发此事件或者正在下载的文件被中断使用什么函数,详细讲解
2024-04-02

编程热搜

目录