使用Ajax下载JQuery文件

前端之家收集整理的这篇文章主要介绍了使用Ajax下载JQuery文件前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

当我的用户选择生成报告时,我正在使用John Culviner的文件下载插件生成“请稍候”消息.

用户单击链接时,我向我的PHP发送ajax请求,该请求在服务器上生成PDF.那时我正在尝试更新fileDownload插件的成功处理程序中的链接.

我可能正在接近这个错误,但这是我的代码 – 非常感谢任何帮助.

$("body").on("click","##pdfLink",function(e){

    $.fileDownload($(this).attr('href'),{
        preparingMessageHtml: "Preparing your report,please wait...",failMessageHtml: "There was a problem generating your report,please try again."
    });

    // Build our data string.
    var strData = {method: "createPDF"};

    // Send a request to build our XL file.
    $.ajax({
        url: '/pdf.PHP',data: strData,type: 'get',dataType: 'json',success: function(data) {
            alert(data);
            $("##pdfLink").attr("href","/pdf/"+data);
        },error: function(e) {
            console.log(e);
        }
    });
    return false; 
    e.preventDefault(); 
})

此时,当我单击链接时,模式会正确显示“请等待”消息.我的文件确实构建在服务器上(在我的成功处理程序中通过我的警报确认),我的HREF确实得到了更新.但是,该插件不会提示用户下载.

谢谢!

最佳答案
你不需要在JS中调用ajax函数.您的链接< a href ='yoursite.com / pdf.PHP'标识此命令$(this).attr('href')您的pdf服务器进程的位置. 编辑: 你的来电:

// Build our data string.
var strData = {method: "createPDF"};

var $preparingFileModal = $("#preparing-file-modal");
$preparingFileModal.dialog({ modal: true });

$.fileDownload($(this).attr('href'),{
    httpMethod: "GET",data: strData
    successCallback: function (responseHtml,url) {
        $preparingFileModal.dialog('close');
        // In this case 
        $.fileDownload("/pdf/"+responseHtml,{
            preparingMessageHtml: "Download file",failMessageHtml: "Not work"
        });

    },failCallback: function (responseHtml,url) {
        $preparingFileModal.dialog('close');
        $("#error-modal").dialog({ modal: true });
    }
});

HTML:

猜你在找的jQuery相关文章