Zeige einen Fortschrittsbalken zum Herunterladen von Dateien mit XHR2 / AJAX

Ich versuche, Dateien mit Ajax herunterzuladen und ein benutzerdefiniertes @ anzuzeigeDownload Fortschrittsbalken.

Das Problem ist, ich kann nicht verstehen, wie das geht. Ich habe den Code geschrieben, um den Fortschritt zu protokollieren, weiß aber nicht, wie ich den Download starten soll.

HINWEIS Es gibt verschiedene Dateitypen.

Danke im Voraus

JS

// Downloading of files
filelist.on('click', '.download_link', function(e){
    e.preventDefault();
    var id = $(this).data('id');
    $(this).parent().addClass("download_start");

    $.ajax({
        xhr: function () {
            var xhr = new window.XMLHttpRequest();
            // Handle Download Progress
            xhr.addEventListener("progress", function (evt) {
                if(evt.lengthComputable) {
                    var percentComplete = evt.loaded / evt.total;
                    console.log(percentComplete);
                }
            }, false);
            return xhr;
        },
        complete: function () {
            console.log("Request finished");
        }
    })
});

HTML und PHP

    <li>
    <div class="f_icon"><img src="' . $ico_path . '"></div>
    <div class="left_wing">
       <div class="progressbar"></div>
       <a class="download_link" href="#" id="'.$file_id.'"><div class="f_name">' . $full_file_name . '</div></a>
       <div class="f_time_size">' . date("M d, Y", $file_upload_time) . '&nbsp; &#149; &nbsp;' . human_filesize($file_size) . '</div>
    </div>

    <div class="right_wing">
       <div class="f_delete">
       <a class="btn btn-danger" href="#" aria-label="Delete" data-id="'.$file_id.'" data-filename="'.$full_file_name.'"><i class="fa fa-trash-o fa-lg" aria-hidden="true" title="Delete this?"></i>
       </a>
    </div>
   </div>
    </li>

Antworten auf die Frage(2)

Ihre Antwort auf die Frage