web-dev-qa-db-fra.com

Bootstrap Barre de progression pour le téléchargement de fichiers MVC

Existe-t-il un moyen simple d'afficher une barre de progression de blocage Bootstrap pendant le chargement d'un fichier?

La progression est affichée dans la barre d'état dans chrome lors du téléchargement du fichier:

The progress is shown in chrome as the file is uploaded

J'aimerais que la boîte de dialogue ressemble à quelque chose comme this

enter image description here

Mon action ressemble à ceci:

 [HttpPost]
        public ActionResult Upload(UploadViewModel model)
        {
                using (MemoryStream uploadedFile = new MemoryStream())
                {
                    model.File.InputStream.CopyTo(uploadedFile);                            
                    uploadService.UploadFile(uploadedFile, model.File.ContentType)
                    return View();
                 }
         }

Modèle:

  public class UploadViewModel
    {
        [Required]
        public HttpPostedFileBase File { get; set; }
    }

Vue:

@model Bleh.Web.Models.UploadViewModel

@using (Html.BeginForm("Upload", "Home",
  FormMethod.Post, new { enctype = "multipart/form-data", @role = "form" }))
{
   <div class="form-group">
    @Html.LabelFor(m => m.File)
    @Html.TextBoxFor(m => m.File, new { type = "file", @class = "form-control" })
    <strong>@Html.ValidationMessageFor(m => m.File, null, new { @class = "label label-danger" })</strong>
</div>

<div class="form-group noleftpadding">
    <input type="submit" value="Upload File" class="btn btn-primary" />
</div>
}

Existe-t-il un moyen simple de traiter le pourcentage affiché par le navigateur et de l'appliquer à la barre de progression?

18
woggles

Le gestionnaire de progression ajax fait-il le travail?

function uploadFile(){
    myApp.showPleaseWait(); //show dialog
    var file=document.getElementById('file_name').files[0];
    var formData = new FormData();
    formData.append("file_name", file);
    ajax = new XMLHttpRequest();
    ajax.upload.addEventListener("progress", progressHandler, false);
    ajax.addEventListener("load", completeHandler, false);
    ajax.open("POST", "/to/action");
    ajax.send(formData);
}

function progressHandler(event){
    var percent = (event.loaded / event.total) * 100;
    $('.bar').width(percent); //from bootstrap bar class
}

function completeHandler(){
    myApp.hidePleaseWait(); //hide dialog
    $('.bar').width(100);
}

Remarque: myApp.showPleaseWait(); et myApp.hidePleaseWait(); sont définis dans le lien fourni par OP.

(edit: formData et formdata étaient auparavant incohérents)

34
vusan