js下载文件

本文的前提是:后台给的是一个可以下载的url的情况下的下载:

怎样的文件url才能触发浏览器的下载行为?(转自SF

能触发浏览器下载的url有两类:

  • response header中指定了Content-Dispositionattachment,它表示让浏览器把响应体作为附件下载到本地 (一般Content-Disposition还会指定filename, 下载的文件默认就是filename指定的名字)

  • response header中指定了Content-Type 为 application/octet-stream(无类型) 或者 application/zip(下载zip包时)以及其它几个不常见类型 (其中还有浏览器差异),其中 application/octet-stream表示http response为二进制流(没指定明确的type), 需要下载到本地, 由系统决定或者用户手动指定打开方式。

在这种前提下,只需要浏览器请求了这个地址,都会自动下载,具体的方式如下:

1、iframe 加载请求此地址时会自动下载  //据说兼容先较好,推荐,使用的时候吧iframe设置为display;none即可  

<iframe name="hehe" src='下载url'></iframe>

2、a  点击请求此地址时会自动下载

  <a href="下载url">下载</a>

  H5的 download 属性 <a download href="下载url">下载</a>  这时候,如果返回的是 img 这种浏览器可以打开的文件时,也会下载(否则会直接打开)

3、form  发起submit请求此地址时会自动下载

<form 
   action="下载ur"
   method="get" 
>
   <button type="submit">下载</button>
</form>

4、window.location.href  赋值为此地址时会自动下载 ,如果是其他地址,会跳转,但,当是下载的url,浏览器会发起请求,下载下来,并且不会改变本页的 window.location.href

  window.location.href = “下载url”

5、window.open 赋值为此地址时会自动下载 ,但会先打开新标签页再下载再关闭新标签页,体验不佳

  window.open(“下载url”)

6、下载二进制流,链接

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值