电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

ASP.NET MVC使用JSAjaxFileUploader插件實(shí)現(xiàn)單文件上傳

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

先看效果:

  • 上傳文件顯示進(jìn)度條:

  • 停止上傳按鈕和關(guān)閉縮略圖按鈕:

  • 限制上傳文件的類型:

  • 限制上傳文件的尺寸:

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

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

HomeController

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

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

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

#region 上傳單個(gè)文件 //顯示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>/// 檢查是否要?jiǎng)?chuàng)建上傳文件夾,如果沒(méi)有就創(chuàng)建/// </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;} //根據(jù)文件名稱刪除文件[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

前臺(tái)視圖主要做如下幾件事:

  • 每次上傳之前檢查表格中是否有數(shù)據(jù),如果有,實(shí)施界面刪除并同步刪除文件夾中的文件
  • 上傳成功動(dòng)態(tài)創(chuàng)建表格行顯示縮略圖、文件名和刪除按鈕
  • 點(diǎn)擊刪除按鈕實(shí)施界面刪除并同步刪除文件夾中的文件

由于表格行是動(dòng)態(tài)生成的,需要對(duì)刪除按鈕以"冒泡"的方式注冊(cè)事件: $('#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字節(jié)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);}    });     //點(diǎn)擊刪除鏈接刪除剛上傳圖片    $("#tbl").on("click", ".delImg", function () {deleteImg();//window.location.reload();    });}); //刪除圖片方法:點(diǎn)擊刪除鏈接或上傳新圖片刪除原先圖片用到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("出錯(cuò)了 "" + jqXhr.status + "" (狀態(tài): "" + textStatus + "", 錯(cuò)誤為: "" + errorThrown + "")");}    });} //創(chuàng)建表格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>

另外:需要?jiǎng)h除源js文件中input元素的multiple屬性,使之只能接收單個(gè)文件。

本篇源碼在github

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

標(biāo)簽: ASP.NET
相關(guān)文章:
主站蜘蛛池模板: 避光流动池-带盖荧光比色皿-生化流动比色皿-宜兴市晶科光学仪器 东莞爱加真空科技有限公司-进口真空镀膜机|真空镀膜设备|Polycold维修厂家 | 回转炉,外热式回转窑,回转窑炉-淄博圣元窑炉工程有限公司 | 定量包装机,颗粒定量包装机,粉剂定量包装机,背封颗粒包装机,定量灌装机-上海铸衡电子科技有限公司 | 协议书_协议合同格式模板范本大全| 黑龙江「京科脑康」医院-哈尔滨失眠医院_哈尔滨治疗抑郁症医院_哈尔滨精神心理医院 | 自动钻孔机-全自动数控钻孔机生产厂家-多米(广东)智能装备有限公司 | 流量卡中心-流量卡套餐查询系统_移动电信联通流量卡套餐大全 | 二手回收公司_销毁处理公司_设备回收公司-找回收信息网 | 齿辊分级破碎机,高低压压球机,立式双动力磨粉机-郑州长城冶金设备有限公司 | 天津暖气片厂家_钢制散热器_天津铜铝复合暖气片_维尼罗散热器 | 电销卡_北京电销卡_包月电话卡-豪付网络 | 优考试_免费在线考试系统_培训考试系统_题库系统_组卷答题系统_匡优考试 | 南京租车,南京汽车租赁,南京包车,南京会议租车-南京七熹租车 | 合肥弱电工程_安徽安防工程_智能化工程公司-合肥雷润 | 西门子气候补偿器,锅炉气候补偿器-陕西沃信机电工程有限公司 | 密集架|电动密集架|移动密集架|黑龙江档案密集架-大量现货厂家销售 | 洁净化验室净化工程_成都实验室装修设计施工_四川华锐净化公司 | 便携式表面粗糙度仪-彩屏硬度计-分体式粗糙度仪-北京凯达科仪科技有限公司 | 电动高压冲洗车_价格-江苏速利达机车有限公司 | ISO9001认证咨询_iso9001企业认证代理机构_14001|18001|16949|50430认证-艾世欧认证网 | 恒温恒湿箱(药品/保健品/食品/半导体/细菌)-兰贝石(北京)科技有限公司 | 红外光谱仪维修_二手红外光谱仪_红外压片机_红外附件-天津博精仪器 | 警方提醒:赣州约炮论坛真的安全吗?2025年新手必看的网络交友防坑指南 | 「阿尔法设计官网」工业设计_产品设计_产品外观设计 深圳工业设计公司 | 水篦子|雨篦子|镀锌格栅雨水篦子|不锈钢排水篦子|地下车库水箅子—安平县云航丝网制品厂 | 警用|治安|保安|不锈钢岗亭-售货亭价格-垃圾分类亭-移动厕所厂家-苏州灿宇建材 | 红立方品牌应急包/急救包加盟,小成本好项目代理_应急/消防/户外用品加盟_应急好项目加盟_新奇特项目招商 - 中红方宁(北京) 供应链有限公司 | 武汉高低温试验机-现货恒温恒湿试验箱-高低温湿热交变箱价格-湖北高天试验设备 | 杜康白酒加盟_杜康酒代理_杜康酒招商加盟官网_杜康酒厂加盟总代理—杜康酒神全国运营中心 | Safety light curtain|Belt Sway Switches|Pull Rope Switch|ultrasonic flaw detector-Shandong Zhuoxin Machinery Co., Ltd | 高考志愿规划师_高考规划师_高考培训师_高报师_升学规划师_高考志愿规划师培训认证机构「向阳生涯」 | 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库-首页-东莞市傲马网络科技有限公司 | 意大利Frascold/富士豪压缩机_富士豪半封闭压缩机_富士豪活塞压缩机_富士豪螺杆压缩机 | 冷凝水循环试验箱-冷凝水试验箱-可编程高低温试验箱厂家-上海巨为(www.juweigroup.com) | 护栏打桩机-打桩机厂家-恒新重工 | 国产频谱分析仪-国产网络分析仪-上海坚融实业有限公司 | 中国品牌门窗网_中国十大门窗品牌_著名门窗品牌 | 深圳市八百通智能技术有限公司官方网站 | 蒜肠网-动漫,二次元,COSPLAY,漫展以及收藏型模型,手办,玩具的新媒体.(原变形金刚变迷TF圈) | 天津拓展_天津团建_天津趣味运动会_天津活动策划公司-天津华天拓展培训中心 | 阿里巴巴诚信通温州、台州、宁波、嘉兴授权渠道商-浙江联欣科技提供阿里会员办理 |