微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用多个文件和输入字段发布表单数据的正确方法是什么

如何解决使用多个文件和输入字段发布表单数据的正确方法是什么

我有一个 ajaxSubmit 实现将表单输入数据和多个文件发布到后端:

    var formData = new FormData();

    formData.append('pictureId',form.find("[name=pictureId]").val());
    formData.append('description',$('input[name=description]').val());
    formData.append('action',$('input[name=action]').val());


    for (var i = 0; i < filesToUpload.length; i++) {
        formData.append('file[]',filesToUpload[i]);
    }

    for (var pair of formData.entries()) {
        console.log(pair[0] + ',' + pair[1]);
    }


    $("#frmPicture").ajaxSubmit({
        type: 'POST',dataType: 'html',cache: false,processData: false,data: formData,success: function (responseText,statusText,xhr,el) {
            debugger;
            if (responseText == "") {
                $("#divAddPictureDialog").dialog("close");
                reloadPictures();
            }
            else {
                $("#spnPictureStatus").html(responseText);
            }
        }
    });

但是这段代码给了我一个错误

Uncaught TypeError: Illegal invocation
    at init.$.fn.ajaxSubmit (jquery.form.js:97)
    at HTMLdivelement.savePicture (HotelDetails.aspx?id=61364:1576)
    at HTMLButtonElement.r.click (jquery-ui-1.10.1.custom.min.js:6)
    at HTMLButtonElement.dispatch (jquery-1.9.1.min.js:3)
    at HTMLButtonElement.v.handle (jquery-1.9.1.min.js:3)

在此之后,我将代码更改为 data: {formData},表单发布发生。但是我无法访问服务器上的文件。密钥 file[] 永远不会发布到后端。

谁能向我建议如何使用 jquery.form.js 正确发送表单数据。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。