0

jqueryファイルアップロードを使用して複数のファイルがアップロードされた後、ページを更新しようとしています:

何らかの理由で、個々のファイルのアップロードが完了するたびにテストメッセージが呼び出され、すべてのファイルがアップロードされた後にこれを1回だけ呼び出そうとしています。これは可能ですか?

HTML:

<form id="fileupload" action="server/php/" method="POST" enctype="multipart/form-data">
    <!-- The fileupload-buttonbar contains buttons to add/delete files and start/cancel the upload -->
    <div class="row fileupload-buttonbar">
        <div class="span7">
            <!-- The fileinput-button span is used to style the file input field as button -->
            <span class="btn btn-success fileinput-button">
                <i class="icon-plus icon-white"></i>
                <span>Add files...</span>
                <input type="file" name="files[]" multiple>
            </span>
            <button type="submit" class="btn btn-primary start">
                <i class="icon-upload icon-white"></i>
                <span>Start upload</span>
            </button>
        </div>
    </div>
    <!-- The loading indicator is shown during file processing -->
    <div class="fileupload-loading"></div>
    <br>
    <!-- The table listing the files available for upload/download -->
    <table role="presentation" class="table table-striped"><tbody class="files" data-toggle="modal-gallery" data-target="#modal-gallery"></tbody></table>
</form>

JQuery

$('#fileupload').bind('fileuploadcompleted', function (e, data) {
    e.preventDefault();

    // I would expect to see this after all files ahve uplaoded but I see it for each file upload ?
    alert("Completed");

    //location.reload();
    ...
})
4

2 に答える 2

1

stopイベントは、すべてのアップロードが終了した後にのみトリガーされます。

$('#fileupload').bind('fileuploadstop', function (e, data) {
    location.reload();
})
于 2016-03-20T13:23:14.597 に答える
0

イベントをリッスンし、fileuploadaddイベントが発生するたびに変数をインクリメントして、アップロードするファイルの数を把握します。次に、fileuploaddoneイベントハンドラーで、別の変数をインクリメントして、終了した変数の数を確認します。2つが等しい場合、すべてのアップロードが完了するので、リロード(またはその他の必要なもの)を実行します。より良い解決策があるはずですが、これはうまくいくはずです。

于 2012-07-21T14:03:18.297 に答える