0

我正在使用带有此 JS 代码的 jQuery 插件jQuery-File-Upload :

  $('#file_upload_single').fileupload({
        dataType: 'json',
        acceptFileTypes: /(\.|\/)(gif|jpe?g|tif|png)$/i,
        maxFileSize: 20000000, // 20MB            
        done: function (e, data) {
            $.each(data.result, function (index, file) {
                var msg = file.name + " upload terminado.";
                $('<p/>').text(msg).appendTo($('#progressLog'));
            });
            $('#progressBar .bar').css('width','0%');
        },
        progressall: function (e, data) {
            var progress = parseInt(data.loaded / data.total * 100, 10);
            $('#progressBar .bar').css('width',progress + '%');
        }
    });

    $('#file_upload_single').bind('fileuploadsubmit', function (e, data) {
        var inputs = data.context.find(':input');
        if (inputs.filter('[required][value=""]').first().focus().length) {
            alert("Por preencher");
            return false;
        }
        data.formData = inputs.serializeArray();
    });

在 HTML 中:

<form id="file_upload_single" action="UploadServlet" method="POST" enctype="multipart/form-data">
            <input id="file_2" type="file" name="file_2" 
                   style="background: gainsboro;" size="70" />
            <p>
                <label for="file_2_title">Título:</label>
                <input id="file_2_title" name="file_2_title" type="text" required title="Título" size="30"/>
            </p>
            <p>
                <label for="file_2_desc">Descritivo</label>
                <input id="file_2_desc" name="file_2_desc" type="text" required title="Descritivo" size="60"/>
            </p>
        </form>
        <button id="formSubmit_single" class="myButton ui-widget ui-state-default ui-corner-all bt_register" 
                type="button" name="formSubmit_single" value="Upload" title="Máx. 20MB cada, do tipo: gif, jpeg, jpg, tif ou png">Imagem única, com descritivo</button>

如果注释了绑定方法,则文件正确上传,但没有完成任何过滤器:acceptFileTypes 和 maxFileSize。在 servlet 中,"String file_2_title = request.getParameter("file_2_title");" 给出空值。

如果没有注释绑定方法(如上),则不会运行!萤火虫显示:

TypeError: data.context is undefined
var inputs = data.context.find(':input');

bind 方法就像在提交表单数据中一样。怎么了?

4

1 回答 1

0

我使用了不同的方法来解决附加表单数据的问题。我在“添加”回调中做到了。

add: function (e, data){
    data.formData = {customInfo: <custom information>};
    data.submit();
},

这工作正常。但我也无法让过滤器工作。

于 2013-08-22T21:48:26.720 回答