asp.net-mvc - MVC 文件上传的 Bootstrap 进度条

标签 asp.net-mvc twitter-bootstrap file-upload twitter-bootstrap-3 progress-bar

有没有一种简单的方法可以在文件加载时显示阻塞的 Bootstrap 进度条?

上传文件时,进度会显示在 chrome 的状态栏中:

The progress is shown in chrome as the file is uploaded

我希望对话框看起来像 this

enter image description here

我的 Action 看起来像这样:

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

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

看法:
@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>
}

有没有一种简单的方法来处理浏览器显示的百分比并将其应用于进度条?

最佳答案

ajax 进度处理程序可以完成这项工作吗?

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);
}

注:myApp.showPleaseWait();myApp.hidePleaseWait();link 中定义由 OP 提供。

(编辑:formData 和 formdata 以前不一致)

关于asp.net-mvc - MVC 文件上传的 Bootstrap 进度条,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24545780/

相关文章:

asp.net-mvc - 带有存储库的静态实用程序类的依赖性问题(.NET MVC 项目)

asp.net - 如何在 ASP.NET MVC View 中检查站点是否在 localhost 或 127.0.0.1 上运行

html - 如何在 div 上设置 100% 高度?

javascript - 如何使数据表内的填充可点击

jquery - Google 应用引擎 Blobstore 上传 URL 过期

Jquery Blueimp 文件上传回调

php - 文件类型 PHP 验证

asp.net-mvc - dll 中的 Ninject 和 Controller

asp.net-mvc - 传递一个简单的 IEnumerable 来查看并使用 foreach 循环会返回空白屏幕?

javascript - 在 Angular 2 typescript 中获取模态元素