美文网首页
post方式实现导出/下载文件

post方式实现导出/下载文件

作者: FrankXu0808 | 来源:发表于2021-07-05 19:55 被阅读0次

https://www.cnblogs.com/shengmo/p/10812481.html
项目需求: 前端需要传入过多的参数给后端,get地址栏不行,只能接受post方式去导出数据
1、get的下载方式
通常下载方式如下:

let url =  xxxx.action?a=xx&b=yy;
 window.location.href = url;
 // 或者
 window.open(url, '_self')

弊端:当请求参数较多时,get的方式无法使用,这时候需要考虑post的方式,但是直接通过ajax的post的方式无法调用浏览器的下载功能

2、post的下载方式
原理: 创建一个隐藏form表单,通过form表单的提交刷新功能,实现下载。代码如下:

this.postExcelFile(
            {
                funcDirIds: dirIds.toString(),
                hasMark: hasMark,
                rootDirid: rpeortRootDirId,
                useCaseLevelExportIds: useCaseLevelsExport
            },
            url
        );

var  postExcelFile=function(params, url) {
                    //params是post请求需要的参数,url是请求url地址
                    var form = document.createElement("form");
                    form.style.display = "none";
                    form.action = url;
                    form.method = "post";
                    document.body.appendChild(form);
                    // 动态创建input并给value赋值
                    for (var key in params) {
                        var input = document.createElement("input");
                        input.type = "hidden";
                        input.name = key;
                        input.value = params[key];
                        form.appendChild(input);
                    }

                    form.submit();
                    form.remove();
                }

相关文章

网友评论

      本文标题:post方式实现导出/下载文件

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