美文网首页时光轴
Vue 内点击 url 下载文件

Vue 内点击 url 下载文件

作者: 侯工 | 来源:发表于2021-12-22 17:01 被阅读0次
    /*
     * 后端返回文件的url,前端创建a标签来下载
     *
     *  1. 解决了若文件为图片或浏览器支持的格式类型,点击下载会直接打开文件的问题,
     *  2. 下载文件时,浏览器会有闪动的问题
     *
     *  页面内使用
     *  1. 引入指令 import downLoad from '@/directive/down-load-url'
     *  2. 注册指令 directives:{downLoad}
     *  3. 使用,在要下载按钮上以指令的形式使用 例如: <el-button v-downLoad="url">下载</el-button>
     */
    
    import downLoad from './downLoad'
    
    const install = function(Vue) {
      Vue.directive('downLoadUrl', downLoad)
    }
    
    downLoad.install = install
    
    export default downLoad
    
    export default {
      bind(el, binding) {
        el.addEventListener('click', () => {
          console.log(binding.value) // url
          const a = document.createElement('a')
          //   let url = baseUrl + binding.value // 若是不完整的url则需要拼接baseURL
          const url = binding.value // 完整的url则直接使用
          // 这里是将url转成blob地址,
          fetch(url).then(res => res.blob()).then(blob => { // 将链接地址字符内容转变成blob地址
            a.href = URL.createObjectURL(blob)
            console.log(a.href)
            a.download = '' // 下载文件的名字
            // a.download = url.split('/')[url.split('/').length -1] //  // 下载文件的名字
            document.body.appendChild(a)
            a.click()
          })
        })
      }
    }
    

    相关文章

      网友评论

        本文标题:Vue 内点击 url 下载文件

        本文链接:https://www.haomeiwen.com/subject/aonqqrtx.html