标签:style blog class code java tar
前段时间做了几个关于图片、文件上传的Demo,使用客户端Query-File-Upload插件和服务端Badkload组件实现多文件异步上传,比如"MVC文件上传04-使用客户端jQuery-File-Upload插件和服务端Backload组件实现多文件异步上传",就Demo而言,效果还算不错,但到了实际项目,发现使用Query-File-Upload插件和服务端Badkload组件与项目比较难融合,有"重"的感觉。相比而言,JSAjaxFileUploader这款插件比较"轻量级",它可以帮我们实现单个文件或多个文件的异步上传和管理,并且有不错的客户端效果,它的Demo在这里。
本篇源码在github,先看效果:
● 上传文件显示进度条:
● 停止上传按钮和关闭缩略图按钮:
● 限制上传文件的类型:
● 限制上传文件的尺寸:
●上传成功后显示缩略图、文件名以及回传信息:
● 点击界面上的删除按钮,界面删除,同步删除文件夹中文件。
●
重新上传文件,界面删除,同步删除文件夹中文件,并界面显示新的缩略图、文件名等。
□ 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="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 class="file_name"></div>
<br />
<div class="file_type"></div>
<br />
<div class="file_size"></div>
<br />
<div class="file_path"></div>
<br />
<div class="file_msg"></div>
</body>
</html>
另外:
需要删除源js文件中input元素的multiple属性,使之只能接收单个文件。
MVC文件图片ajax上传轻量级解决方案,使用客户端JSAjaxFileUploader插件01-单文件上传,布布扣,bubuko.com
MVC文件图片ajax上传轻量级解决方案,使用客户端JSAjaxFileUploader插件01-单文件上传
标签:style blog class code java tar
原文地址:http://www.cnblogs.com/darrenji/p/3703453.html