html页面实现点击下载文件(js)

    科技2022-08-16  116

    .使用标签来完成

    < a href=" " 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=/plugins.maintain.CheckLinePartTask/cebab687-6dc5-4128-b7d9-8bc2fe369598.png&raw=1" download="test.png">点击下载</ a> </body> </html>

    其中download后面的属性是下载后文件的文件名字

    如果url指向同源资源,是正常的。

    如果url指向第三方资源,download会失效,表现和不使用download时一致——浏览器能打开的文件,浏览器会直接打开,不能打开的文件,会直接下载。浏览器打开的文件,可以手动下载。

    解决方案一:将文件打包为.zip/.rar等浏览器不能打开的文件下载。

    解决方案二:通过后端转发,后端请求第三方资源,返回给前端,前端使用file-saver等工具保存文件。 2.使用按钮进行监听

    按钮监听又可以分为两种方法,

    一是window.open()

    var $eleBtn1 = $("#btn1"); var $eleBtn2 = $("#btn2"); //已知一个下载文件的后端接口:https://codeload.github.com/douban/douban-client/legacy.zip/master //方法一:window.open() $eleBtn1.click(function(){ window.open("https://codeload.github.com/douban/douban-client/legacy.zip/master"); });

    二是表单提交

    //方法二:通过form $eleBtn2.click(function(){ var $eleForm = $("<form method='get'></form>"); $eleForm.attr("action","https://codeload.github.com/douban/douban-client/legacy.zip/master"); $(document.body).append($eleForm); //提交表单,实现下载 $eleForm.submit(); });
    Processed: 0.018, SQL: 9