1.使用<a>标签来完成
<a href="/user/test/" download="文件名.txt">点击下载</a>
这样当用户打开浏览器点击链接的时候就会直接下载文件。
但是有个情况,比如txt,png,jpg等这些浏览器支持直接打开的文件是不会执行下载任务的,而是会直接打开文件,这个时候就需要给a标签添加一个属性“download”;
以下为例子
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<a href="http://171.**.96.**:****/d/c833945c11/files/?p=//&raw=1"
download="">点击下载</a>
</body>
</html>
其中download后面的属性是下载后文件的文件名字
如果url指向同源资源,是正常的。
如果url指向第三方资源,download会失效,表现和不使用download时一致——浏览器能打开的文件,浏览器会直接打开,不能打开的文件,会直接下载。浏览器打开的文件,可以手动下载。
解决方案一:将文件打包为.zip/.rar等浏览器不能打开的文件下载。
解决方案二:通过后端转发,后端请求第三方资源,返回给前端,前端使用file-saver等工具保存文件。
2.使用按钮进行监听
按钮监听又可以分为两种方法,
一是()
var $eleBtn1 = $("#btn1");
var $eleBtn2 = $("#btn2");
//已知一个下载文件的后端接口:/douban/douban-client//master
//方法一:()
$(function(){
("/douban/douban-client//master");
});
二是表单提交
//方法二:通过form
$(function(){
var $eleForm = $("<form method='get'></form>");
$("action","/douban/douban-client//master");
$().append($eleForm);
//提交表单,实现下载
$();
});