日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

ASP.NET MVC使用JSAjaxFileUploader插件實現單文件上傳

瀏覽:613日期:2022-06-08 10:48:41

先看效果:

  • 上傳文件顯示進度條:

  • 停止上傳按鈕和關閉縮略圖按鈕:

  • 限制上傳文件的類型:

  • 限制上傳文件的尺寸:

  • 上傳成功后顯示縮略圖、文件名以及回傳信息:

  • 點擊界面上的刪除按鈕,界面刪除,同步刪除文件夾中文件。
  • 重新上傳文件,界面刪除,同步刪除文件夾中文件,并界面顯示新的縮略圖、文件名等。

HomeController

由于需要把保存到文件夾文件的路徑、文件名等回傳給界面,所以需要一個類,專門負責回傳給客戶端所需要的信息。

    public class UploadFileResult    {public string FileName { get; set; }public int Length { get; set; }public string Type { get; set; }public bool IsValid { get; set; }public string Message { get; set; }public string FilePath { get; set; }     }

把上傳的文件名改成以時間命名的格式,并保存到文件夾,再把回傳信息以json形式傳遞給視圖。關于刪除,需要接收來自視圖的文件名參數。

#region 上傳單個文件 //顯示public ActionResult Index(){    return View();} //接收上傳[HttpPost]public ActionResult UploadFile(){    List<UploadFileResult> results = new List<UploadFileResult>();    foreach (string file in Request.Files)    {HttpPostedFileBase hpf = Request.Files[file] as HttpPostedFileBase;if (hpf.ContentLength == 0 || hpf == null){    continue;} var fileName = DateTime.Now.ToString("yyyyMMddhhmmss") +       hpf.FileName.Substring(hpf.FileName.LastIndexOf("."));string pathForSaving = Server.MapPath("~/AjaxUpload");if (this.CreateFolderIfNeeded(pathForSaving)){    hpf.SaveAs(Path.Combine(pathForSaving, fileName));    results.Add(new UploadFileResult()    {FilePath = Url.Content(String.Format("~/AjaxUpload/{0}", fileName)),FileName = fileName,IsValid = true,Length = hpf.ContentLength,Message = "上傳成功",Type = hpf.ContentType    });}    }     return Json(new    {name = results[0].FileName,type = results[0].Type,size = string.Format("{0} bytes", results[0].Length),path = results[0].FilePath,msg = results[0].Message    });}     #region 共用方法/// <summary>/// 檢查是否要創建上傳文件夾,如果沒有就創建/// </summary>/// <param name="path">路徑</param>/// <returns></returns>private bool CreateFolderIfNeeded(string path){    bool result = true;    if (!Directory.Exists(path))    {try{    Directory.CreateDirectory(path);}catch (Exception){    //TODO:處理異常    result = false;}    }    return result;} //根據文件名稱刪除文件[HttpPost]public ActionResult DeleteFileByName(string name){    string pathForSaving = Server.MapPath("~/AjaxUpload");    System.IO.File.Delete(Path.Combine(pathForSaving, name));    return Json(new    {msg = true    });}#endregion

Home/Index.cshml

前臺視圖主要做如下幾件事:

  • 每次上傳之前檢查表格中是否有數據,如果有,實施界面刪除并同步刪除文件夾中的文件
  • 上傳成功動態創建表格行顯示縮略圖、文件名和刪除按鈕
  • 點擊刪除按鈕實施界面刪除并同步刪除文件夾中的文件

由于表格行是動態生成的,需要對刪除按鈕以"冒泡"的方式注冊事件: $('#tb').on("click", ".delImg", function ()

<html><head>    <meta name="viewport" content="width=device-width" />    <title>Index</title>    <link href="~/Content/JSAjaxFileUploader/JQuery.JSAjaxFileUploader.css" rel="external nofollow"  rel="stylesheet" />    <script src="~/Scripts/jquery-1.10.2.js"></script>    <script src="~/Scripts/JSAjaxFileUploader/JQuery.JSAjaxFileUploaderSingle.js"></script>    <style type="text/css">#tb table{    border-collapse: collapse;          width: 600px; } #tb td {    text-align: center;    padding-top: 5px;    width: 25%;} #tb tr {    background-color: #E3E3E3;    line-height: 35px;} .showImg {    width: 50px;    height: 50px;}    </style>    <script type="text/javascript">$(function () {    //隱藏顯示圖片的表格    $("#tbl").hide();     $("#testId").JSAjaxFileUploader({uploadUrl: "@Url.Action("UploadFile","Home")",inputText: "選擇上傳文件",//fileName: "photo",maxFileSize: 512,    //Max 500 KB file 1kb=1024字節allowExt: "gif|jpg|jpeg|png",zoomPreview: false,zoomWidth: 360,zoomHeight: 360,beforesend: function (file) {    if ($(".imgName").text() != "") {deleteImg();$("#tbl").hide();    }},success: function (data) {    $(".file_name").html(data.name);    $(".file_type").html(data.type);    $(".file_size").html(data.size);    $(".file_path").html(data.path);    $(".file_msg").html(data.msg);    createTableTr();    $("#tbl").show();    $(".showImg").attr("src", data.path);    $(".imgName").text(data.name);},error: function (data) {    alert(data.msg);}    });     //點擊刪除鏈接刪除剛上傳圖片    $("#tbl").on("click", ".delImg", function () {deleteImg();//window.location.reload();    });}); //刪除圖片方法:點擊刪除鏈接或上傳新圖片刪除原先圖片用到function deleteImg() {    $.ajax({cache: false,url: "@Url.Action("DeleteFileByName", "Home")",type: "POST",data: { name: $(".imgName").text() },success: function (data) {    if (data.msg) {//alert("圖片刪除成功");$(".delImg").parent().parent().remove();    }},error: function (jqXhr, textStatus, errorThrown) {    alert("出錯了 "" + jqXhr.status + "" (狀態: "" + textStatus + "", 錯誤為: "" + errorThrown + "")");}    });} //創建表格function createTableTr() {    var table = $("#tbl");    table.append("<tr><td><img class="showImg"/></td><td colspan="2"><span class="imgName"></span></td><td><a class="delImg" href="javascript:void(0)">刪除</a></td></tr>");}    </script></head><body>    <div id="testId"></div>        <div id="tb"><table id="tbl">    <tbody>     </tbody></table>    </div><div></div><br /><div></div><br /><div></div><br /><div></div><br /><div></div></body></html>

另外:需要刪除源js文件中input元素的multiple屬性,使之只能接收單個文件。

本篇源碼在github

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對的支持。如果你想了解更多相關內容請查看下面相關鏈接

標簽: ASP.NET
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
午夜欧美理论片| 欧美片网站免费| 国产日韩1区| 国产乱码精品一区二区三区亚洲人| 亚洲色图国产| 国产探花一区在线观看| 国产欧美在线| av资源新版天堂在线| 中文字幕系列一区| 99视频精品| 日韩动漫一区| 色婷婷色综合| 日韩成人三级| 国产麻豆综合| 欧美啪啪一区| 日韩中文字幕高清在线观看| 先锋影音久久久| 国产精品网址| 久久精品91| 日韩精品一区二区三区中文字幕| 欧美国产另类| 亚洲成人三区| 国产精品久久久久9999高清| 久久久天天操| 日本v片在线高清不卡在线观看| 精品视频一区二区三区在线观看 | 91视频久久| 在线亚洲一区| 麻豆久久一区| 三级亚洲高清视频| 国产精品精品国产一区二区| 国产精品毛片在线| 婷婷综合一区| 久久中文字幕av一区二区不卡| 国产亚洲毛片| 激情久久一区二区| 亚洲开心激情| 久久国产成人午夜av影院宅| 国产日韩精品视频一区二区三区| 激情欧美一区二区三区| 精品三区视频| 欧美日韩一区自拍| 欧美日韩视频| 久久久久久久久久久9不雅视频| 欧美日本二区| 亚洲综合图色| 红桃视频亚洲| 免费不卡中文字幕在线| 理论片午夜视频在线观看| 玖玖精品视频| 99riav1国产精品视频| 欧美freesex黑人又粗又大| 国产一区二区三区网| 国产精品片aa在线观看| 日韩精品亚洲一区二区三区免费| 麻豆成全视频免费观看在线看| 久久女人天堂| 国产一区二区三区国产精品| 欧美激情福利| 麻豆成人在线观看| 久久影院资源站| 国产aⅴ精品一区二区三区久久| 国产精品香蕉| 岛国精品一区| 精品久久免费| 久久国产欧美| 鲁大师成人一区二区三区| 亚洲欧美日韩一区在线观看| 国产精品毛片一区二区三区| 玖玖精品视频| 欧美日韩亚洲国产精品| 国产日韩一区二区三免费高清 | 国产精品一区免费在线| 日本国产亚洲| 久久国产精品亚洲77777| 日本午夜精品久久久久| 精品国产一区二区三区噜噜噜| 国产精品毛片视频| 日本不良网站在线观看| 午夜日韩av| 91精品一区| 日韩国产一区| 亚洲欧洲av| 精品国内亚洲2022精品成人| 国产一区日韩一区| 日本v片在线高清不卡在线观看| 国产中文欧美日韩在线| 国产亚洲一区在线| 精品理论电影在线| 免费观看在线色综合| 国产66精品| 久久最新视频| 国产成人免费| 蜜臀a∨国产成人精品| 久久久久久网| 亚洲人成网77777色在线播放| 精品国产第一福利网站| 久久成人一区| 日韩精品一区二区三区免费观看| 亚洲人妖在线| 激情五月综合网| av资源新版天堂在线| 91麻豆精品| 亚洲三区欧美一区国产二区| 日韩一区三区| 国产乱人伦丫前精品视频| 99成人在线| 国产高潮在线| 久久精品五月| 欧美精品福利| 亚洲日韩视频| 一区二区精品| 国产精品腿扒开做爽爽爽挤奶网站| www在线观看黄色| 国产精品一区三区在线观看| 日韩精品福利一区二区三区| 国产精品普通话对白| 欧美aa国产视频| 99精品电影| 美女亚洲一区| 亚洲欧洲一区二区天堂久久| 久久一级电影| 日韩成人亚洲| 亚洲午夜精品久久久久久app| 国产精品亚洲一区二区三区在线观看| 麻豆精品视频在线观看免费| 国产日产高清欧美一区二区三区 | 国产一区2区在线观看| 欧美xxxx性| 精品精品99| 国产美女高潮在线观看| 裤袜国产欧美精品一区| 日韩三区免费| 91精品精品| 欧美日韩一区二区三区视频播放| 久久久久久久久99精品大| 黄色亚洲大片免费在线观看| 香蕉国产精品| 日韩一区二区三区四区五区| 日韩精品电影一区亚洲| 国产精品久久免费视频| 国产成年精品| 久久国产影院| 蜜臀av一区二区三区| 国产精品久久久久9999高清| 黑人精品一区| 女主播福利一区| 日韩av午夜在线观看| 国产精品videossex| av资源亚洲| 视频一区二区欧美| 久久精品国产福利| 日韩视频免费| 免费看一区二区三区| 黄色亚洲精品| 国产精品黄色| 国产精品毛片一区二区三区| 国产精品xxx在线观看| 欧美中文一区二区| 欧美午夜三级| 国产视频久久| 成人在线免费观看91| 亚洲色图国产| 亚洲1234区| 国产精品欧美大片| 免费日韩av| 亚洲午夜电影| 91av亚洲| 成人综合一区| 国产精品一区毛片| 一区二区电影| 欧美日韩精品一本二本三本| 日韩大片在线| 精品国产aⅴ| 国产日韩欧美中文在线| 蜜臀精品久久久久久蜜臀 | 蜜桃一区二区三区| 日韩国产激情| 亚洲天堂资源| 麻豆国产精品视频| 国产精品综合色区在线观看| 亚洲日本国产| 亚洲精品伊人| 亚洲一级淫片| 日韩精选在线| 国产日韩欧美高清免费| 日本一区二区三区视频在线看| 黄色精品网站| 日韩视频久久| 中文亚洲免费| 国产精品人人爽人人做我的可爱| 欧美日韩国产一区二区三区不卡| 日韩精品永久网址| 国产精品蜜芽在线观看| 成人三级高清视频在线看| 久久精品影视| 欧美资源在线| 国产日韩欧美一区二区三区 | 国产亚洲在线| 亚洲精一区二区三区|