美文网首页
文件下载

文件下载

作者: 阿凯_8b27 | 来源:发表于2019-07-18 09:55 被阅读0次

angluar中文件下载常用的处理方法
接口是Get情况

const url =  "https://www.jianshu.com/writer#/notebooks/38692933/notes/50835681"
1.采用window的下载机制
    window.location.href = url;
好处:简单易懂
坏处:接口如果有问题,画面就崩溃
window.open().location.href = url;
好处:接口有问题,不影响当前画面
坏处:效果不好,会打卡新窗口
2.采用iframe
    html渲染一个隐藏的iframe;
    <iframe src="" #video style="display: none" frameborder="0"></iframe>

ts获取dom,赋值url即可

@ViewChild('video') IframeView: ElementRef;
this.IframeView.nativeElement.src = url;
3.接口是POST情况
引入file-saver类库

1.在http请求中加入参数, reportProgress: true, responseType: 'blob',

request(url, params?: any){

    const req = new HttpRequest(

      'POST',

      this.SERVER_URL+url,

      params,

      {

        headers: this.parseHeaders(),

        reportProgress: true,

        responseType: 'blob',

      },

    );

    return this.http

      .request(req);

  }

import { saveAs } from 'file-saver';
//此处写自己的业务url,参数

this.http.request('api/v1/Export',obj).subscribe(

          (event: any) => {

          if (event.type === HttpEventType.ResponseHeader) {

          let headerName = event.headers.get('Content-Disposition')

          this.fileName = decodeURIComponent(headerName).substring(21)? decodeURIComponent(headerName).substring(21):this.fileName;

            } else if (event.type === HttpEventType.DownloadProgress) {

            } else if (event instanceof HttpResponse) {

              saveAs(event.body,this.fileName);//文件流和文件名

            //  resolve(true);

            }

          },

          err => {

            reject(err);

          },

        );

.

相关文章

  • Android 零碎知识点和技巧

    使用DownloadManager下载文件 下载文件 监听下载结果 文件下载断点续传 1.获取已下载的文件长度. ...

  • js文件下载

    1.文件流下载 根据后台接口文件流下载 调用 2.文件地址下载 根据文件地址下载文件 调用 3.base64流下载...

  • wget下载数据

    下载单个文件 -nc: 继续下载中断的操作 下载目录下面所有文件 下载多个文件:

  • 文件下载

    由于不同的浏览器兼容不同,对于直接a标签下载文件,有的浏览器可以,有的浏览器会直接播放。为了保证下载操作的正确执行...

  • 文件下载

    常见的文件格式: 文件下载HTML 图片文件下载PHP

  • 文件下载

    IOUtils 的对应包 需要关闭流的对象放在try()内不用写关闭代码

  • 文件下载

    文件下载是实际项目中经常用的一个接口,不同于图片下载客户端自己保存就可以了,需要开放对应的接口。同时,一般会结合P...

  • 文件下载

    1.小文件下载 1.1下载方式 【NSData dataWithContentsOfURL:】 [NSURLCon...

  • 文件下载

  • 文件下载

    初始化下载管理器 添加下载 下载数据管理 创建请求 Get Post Delegate 下载数据本地化 创建任务 ...

网友评论

      本文标题:文件下载

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