Index.cshtml
@{
Layout = null;
}
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="initial-scale=1, maximum-scale=1">
<title>圖片上傳Demo</title>
<script src="@Url.Content("~/js/jquery.min.js")"></script>
<script src="@Url.Content("~/js/jquery.h5upload.js")"></script>
</head>
<body>
<div>
h5圖片上傳控制元件使用方法:
<ol>
<li>引入jQuery</li>
<li>引入jQuery.h5upload</li>
<li>$("#id").h5upload();</li>
</ol>
<div style="color:red;font-size:12px;">
本控制元件非非同步上傳,提交後伺服器根據表單name獲取上傳後的圖片
</div>
</div>
<form action="/King/Upload" enctype="multipart/form-data" method="post">
<input type="text" name="uptext" size=20 />
<div id="inputfiles">
</div>
<input type="submit" />
</form>
<script>
$("#inputfiles").h5upload();
</script>
</body>
</html>
jquery.h5upload.js
(function (jq) {
jq.fn.h5upload = function (opt, msg) {
opt = jq.extend({ exts: ['jpg', 'gif', 'png', 'jpeg'], max: 9, size: 3145728, del: true, name: 'uploadfile[]' }, opt);
msg = jq.extend({ exts: "檔案格式不合法!", max: "最多允許上傳" + opt.max + "張", size: "檔案大小不得超過" + (opt.size / 1024) + "kb", del: "是否移除此影象?" }, msg);
var $self = $(this);
var $plus = null;
var curFileCount = 0;
function onadd() {
$self.find("input[name=" + opt.name + "]:last").click();
}
function addEvent($input) {
$input.change(function () {
var file = this.files[0];
if (checkFile(file)) {
var r = new FileReader();
r.readAsDataURL(file);
r.onload = function () {
$imgdiv = $("<div class='h5upload_item h5upload_img' style='background-image:url(" + this.result + ")'></div>");
$imgclose = $("<img class='h5upload_delimg' src='" + closeimg + "'/>");
$imgclose[0].link = [$input, $imgdiv];
$imgclose.click(function () {
removefile(this);
});
$plus.before($imgdiv.append($imgclose));
newfile();
}
}
});
}
function addInput($parent) {
return $("<input type='file' name='" + opt.name + "' style='display:none'/>").appendTo($parent);
}
function newfile() {
curFileCount++;
if (curFileCount > opt.max) {
$plus.hide();
}
$input = addInput($self);
addEvent($input);
}
function removefile(base) {
if (!opt.del || confirm(msg.del)) {
base.link[0].remove();
base.link[1].remove();
curFileCount--;
if (curFileCount <= opt.max) {
$plus.show();
}
}
}
function init() {
$plus = $("<img src='" + plusimg + "' class='h5upload_item'/>");
$self.append($plus).append("<div class='h5upload_clear'></div>");
$plus.click(onadd);
return $plus;
}
function checkFile(file) {
var sps = file.name.split(".");
if (sps.length < 2) return falsemsg('exts');
if (opt.exts.indexOf(sps[1].toLowerCase()) < 0) return falsemsg('exts');
if (file.size > opt.size) return falsemsg("size");
return true;
}
function falsemsg(key) {
if (msg[key]) alert(msg[key]); return false;
}
$plus = init();
newfile();
}
var plusimg = "";
var closeimg = "";
var style = ".h5upload_item{float:left;width:100px;height:100px;margin:5px}.h5upload_clear{clear:both}.h5upload_img{background-size:cover;position:relative}.h5upload_delimg{position:absolute;top:-5px;right:-5px;width:20px;height:20px}";
document.write("<style>" + style + "</style>")
})(jQuery);
KingController.cs
using MbDemo.Models;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Web;
using System.Web.Mvc;
namespace MbDemo.Controllers
{
public class KingController : Controller
{
public ActionResult Index()
{
ViewBag.Message = "Welcome to ASP.NET MVC!";
return View();
}
[HttpPost]
public ActionResult Upload()
{
HttpFileCollectionBase files = Request.Files;
StringBuilder builder = new StringBuilder();
for (int i = 0; i < files.Count; i++)
{
builder.Append("檔案 name: " + files[i].FileName + " size: " + files[i].ContentLength + "<br>");
}
return Content(builder.ToString());
}
}
}
執行結果如圖: