能触发浏览器下载的url有两类:segmentfault
response header中指定了Content-Disposition为attachment,它表示让浏览器把响应体做为附件下载到本地 (通常Content-Disposition还会指定filename, 下载的文件默认就是filename指定的名字)浏览器
response header中指定了Content-Type 为 application/octet-stream(无类型) 或者 application/zip(下载zip包时)以及其它几个不常见类型 (其中还有浏览器差别),其中 application/octet-stream表示http response为二进制流(没指定明确的type), 须要下载到本地, 由系统决定或者用户手动指定打开方式。app
在这种前提下,只须要浏览器请求了这个地址,都会自动下载,具体的方式以下:学习
一、iframe 加载请求此地址时会自动下载 //听说兼容先较好,推荐,使用的时候吧iframe设置为display;none便可url
<iframe name="hehe" src='下载url'></iframe>spa
二、a 点击请求此地址时会自动下载code
<a href="下载url">下载</a>orm
H5的download属性 <a download href="下载url">下载</a> 这时候,若是返回的是img这种浏览器能够打开的文件时,也会下载(不然会直接打开)blog
三、form 发起submit请求此地址时会自动下载ip
<form action="下载ur" method="get" > <button type="submit">下载</button> </form>
四、window.location.href 赋值为此地址时会自动下载 ,若是是其余地址,会跳转,但,当是下载的url,浏览器会发起请求,下载下来,而且不会改变本页的 window.location.href
window.location.href = “下载url”
四、window.open 赋值为此地址时会自动下载 ,但会先打开新标签页再下载再关闭新标签页,体验不佳
window.open = “下载url”
总之:只要是下载的url,只要让浏览器发起请求,都会实现下载的功能;具体是什么缘由,有待后期的学习。(我司是汪大神,分分钟就说出了这个规律,想必必然有基础理论的支持,也许是HTTP请求、或者后台知识的)