jQuery - 使用输入多个循环发布单个文件

时间:2015-01-20 18:03:26

标签: php jquery ajax forms file-upload

我需要使用多表单形式发布jQuery文件。 问题是我不知道如何使用foreach循环单独发送每个文件,因此我可以分别从每个文件中获取上传成功。

这是我将每个文件发送到PHP的功能:

        var fileInput = document.getElementById ("images_upload_new_album");
        if ('files' in fileInput) {
            //console.log(fileInput.files);
            $.each(fileInput.files, function(index, val) {
                 /* iterate through array or object */
                 console.log(fileInput.files[index]);
                $.ajax({
                    url: config.site + "admin/photos/upload_test",
                    type: 'POST',
                    data: {file: fileInput.files[index].name},
                    dataType: 'json',
                    mimeType:"multipart/form-data",
                    contentType: false,
                    cache: false,
                    processData:false,
                    beforeSend: function (data) {
                        console.log("Before send.");
                        //console.log(data);
                    }, // AJAX request is about to be sent
                    complete: function (data) {
                        console.log("Complete.");
                        //console.log(data);
                    }, // AJAX request has completed
                    success: function(data, textStatus, jqXHR) // AJAX request has completed successfully
                    {
                        console.log("success.");
                        console.log(data);
                    },
                    error: function(jqXHR, textStatus, errorThrown) // AJAX request has completed with errors
                    {
                        console.log("error.");
                    }
                });
            });
        };

我的PHP测试功能。

public function upload_test()
{
    $received = $_FILES;
    echo json_encode($received);
}

我从控制台获得了什么:

File {webkitRelativePath: "", lastModified: 1418160606000, lastModifiedDate: Tue Dec 09 2014 20:30:06 GMT-0100 (Hora padrão dos Açores), name: "100371.jpg", type: "image/jpeg"…}
Before send.
Modal it's opened
success.
[]
Complete.

这是我的多种形式:

<form action="http://xxxxxxx.dev/admin/photos/upload" id="upload_form" enctype="multipart/form-data" method="post" accept-charset="utf-8">
<input type="file" name="images_upload_new_album[]" value="" id="images_upload_new_album" class="hidden_images_upload" style="visibility: hidden; width: 0px; height: 0px" multiple="multiple" accept=".jpg"  />
</form>

1 个答案:

答案 0 :(得分:0)

我通过重新创建POST循环来解决问题:

    $('#new-album-modal').on('show.bs.modal', function (e) {
        // Runs after show modal event is fired
        var fileInput = document.getElementById ("images_upload_new_album");
        if ('files' in fileInput) {
            jQuery.each($('#images_upload_new_album')[0].files, function(i, file) {
                var data = new FormData();
                data.append('fileinput', file);
                $.ajax({
                    url: config.site + "admin/photos/upload_test",
                    type: 'POST',
                    data: data,
                    dataType: 'json',
                    mimeType:"multipart/form-data",
                    contentType: false,
                    cache: false,
                    processData:false,
                    beforeSend: function (data) {
                        console.log("Before send.");
                        //console.log(data);
                    }, // AJAX request is about to be sent
                    complete: function (data) {
                        console.log("Complete.");
                        //console.log(data);
                    }, // AJAX request has completed
                    success: function(data, textStatus, jqXHR) // AJAX request has completed successfully
                    {
                        console.log("success.");
                        console.log(data);
                    },
                    error: function(jqXHR, textStatus, errorThrown) // AJAX request has completed with errors
                    {
                        console.log("error.");
                    }
                });
            });
        };
    });

此问题已根据以下帖子解决:http://stackoverflow.com/questions/5392344/sending-multipart-formdata-with-jquery-ajax