第一步:css
引入文件html
<!--引入CSS-->
<link href="~/Content/JS/webuploader.css" rel="stylesheet" />
<!--引入JS-->
<script src="~/Content/JS/webuploader.js"></script>web
第二步:app
/spa
/文本多個上傳 function UploadMultiFile() { var uploader = WebUploader.create({ // 選完文件後,是否自動上傳。 auto: true, // swf文件路徑 swf: '~/Content/JS/Uploader.swf', // 文件接收服務端。 server: '/Import/AllUpload', // 選擇文件的按鈕。可選。 // 內部根據當前運行是建立,多是input元素,也多是flash. pick: '#picker', // 不壓縮image, 默認若是是jpeg,文件上傳前會壓縮一把再上傳! resize: false, fileVal:'fileData' }); // 當有文件被添加進隊列的時候 uploader.on('fileQueued', function (file) { var itemTemplate = ""; var fileSize = parseInt(file.size / 1024); if (fileSize >= 1024) fileSize = parseInt(fileSize / 1024) + "MB" else fileSize = parseInt(fileSize) + "KB" itemTemplate = '<div id="' + file.id + '" class="uploadify-queue-item">\ <div style="width:50px;margin-right:2px;"><img src="/Content/Img/word.png" style="width:20px;height:20px;"></div>\ <div class="cancel">\ <a href=""></a>\ </div>\ <span class="fileName">'+ file.name + ' (' + fileSize + ')</span><span class="data"></span>\ </div>'+ itemTemplate; $(".border").prepend(itemTemplate); $(".drag-tip").remove(); }); // 文件上傳過程當中建立進度條實時顯示。 uploader.on('uploadProgress', function (file, percentage) { var $li = $('#' + file.id), $percent = $li.find('.uploadify-progress .uploadify-progress-bar'); // 避免重複建立 if (!$percent.length) { $percent = $('<div class="uploadify-progress uploadify-progress-striped active">' + '<div class="uploadify-progress-bar" role="progressbar" style="width: 0%">' + '</div>' + '</div>').appendTo($li).find('.uploadify-progress-bar'); } $li.find('.data').text(' 上傳中').css("color", "red");; $percent.css('width', percentage * 100 + '%'); }); //文件成功、失敗處理 uploader.on('uploadSuccess', function (file) { $('#' + file.id).find('.data').text(' 上傳成功').css("color", "green"); }); uploader.on('uploadError', function (file) { $('#' + file.id).find('.data').text(' 上傳出錯'); }); uploader.on('uploadComplete', function (file) { $('#' + file.id).find('.uploadify-progress').fadeOut(); }); }
第三步:code
html標籤server
<div style="height: 38px;">
<div id="uploader" class="wu-example">
<!--用來存放文件信息-->
<div id="fileList" class="uploader-list"></div>
<div class="btns">
<div id="picker">標準文本批量導入(選擇文件)</div>
</div>
</div>
</div>
<div class="border" style="height: 200px; border-radius: 5px;overflow-y:scroll">
</div>htm
第四步:blog
後臺代碼隊列
1 [AcceptVerbs(HttpVerbs.Post)] 2 public JsonResult AllUpload(HttpPostedFileBase fileData) 3 { 4 if (fileData != null) 5 { 6 try 7 { 8 //string H = ""; 9 string filePath = Common.Url; 10 if (fileData != null && fileData.ContentLength > 0) 11 { 12 string fileName = Path.GetFileName(fileData.FileName);//原始文件名稱 13 string fileExtension = Path.GetExtension(fileName); // 文件擴展名 14 15 string aFirstName = fileName.Substring(fileName.LastIndexOf("\\") + 1, (fileName.LastIndexOf(".") - fileName.LastIndexOf("\\") - 1)); //文件名 16 string StdNo = ""; 17 if (aFirstName.Contains("%")) 18 StdNo = aFirstName.Split('%')[0].Replace("_", "/"); 19 else 20 StdNo = aFirstName.Replace("_", "/"); 21 var S = db.Standards.FirstOrDefault(n => n.StdNo == StdNo); 22 if (S != null) 23 { 24 string fileName1 = DateTime.Now.ToString("yyyyMMddHHmmss") + Common.NO(S.StdNo) + Path.GetExtension(fileData.FileName); 25 filePath = filePath + Common.NO(fileName1); 26 if (System.IO.File.Exists(S.Url)) 27 System.IO.File.Delete(S.Url); 28 fileData.SaveAs(filePath); 29 } 30 } 31 32 return Json(new { Success = true, FileName = Path.GetFileName(fileData.FileName), SaveName = Path.GetFileName(fileData.FileName) }); 33 } 34 catch (Exception ex) 35 { 36 return Json(new { Success = false, Message = ex.Message }, JsonRequestBehavior.AllowGet); 37 } 38 } 39 else 40 { 41 return Json(new { Success = false, Message = "請選擇要上傳的文件!" }, JsonRequestBehavior.AllowGet); 42 } 43 }