原有參考網上百度出來的很多博主所寫的信息,大部分是他們的結晶,再次感謝
寫這個博文主要是爲了給自己留下個記錄,方便以後的使用
先貼上前端的代碼
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>產品特性Form</title>
<link href="~/Content/Base/layui/css/layui.css" rel="stylesheet" type="text/css" />
<script src="~/Content/Base/layui/layui.js" type="text/javascript"></script>
<script src="../../../../Content/Views/js/jquery-1.8.3.min.js" type="text/javascript"></script>
<script src="../../../../Content/Views/js/framework-ui.js" type="text/javascript"></script>
<style>
@*table
{
height: 150px;
}
.layui-form-label
{
width: 100px;
}*@
</style>
</head>
<body>
<div style="width:100%;">
<div class="layui-upload">
<button type="button" class="layui-btn layui-btn-normal" id="testList">選擇多文件</button>
<div class="layui-upload-list">
<table class="layui-table" id="tableFile">
<thead>
<tr><th>文件名</th>
<th>大小</th>
<th>狀態</th>
<th>操作</th>
</tr></thead>
<tbody id="demoList"></tbody>
</table>
</div>
<button type="button" class="layui-btn" id="testListAction">開始上傳</button>
</div>
</div>
<script>
function getModelName() {
var url = location.search; //獲取url中"?"符後的字串
var theRequest = new Object();
if (url.indexOf("?") != -1) {
var str = url.substr(1);
strs = str.split("&");
for (var i = 0; i < strs.length; i++) {
theRequest[strs[i].split("=")[0]] = unescape(strs[i].split("=")[1]);
}
}
return theRequest;
};
var parentUrlObj = getModelName();
var FileType = decodeURI(escape(parentUrlObj['filetype']));
var ModelId = decodeURI(escape(parentUrlObj['modelId']));
var NodeId = decodeURI(escape(parentUrlObj['nodeid']));
var ProductId = decodeURI(escape(parentUrlObj['productid']));
layui.use(['form', 'upload'], function () {
var form = layui.form,
upload = layui.upload;
var demoListView = $('#demoList')
, uploadListIns = upload.render({
elem: '#testList'
, url: '/ModelList/uploadNodeAttributeFile?filetype=' + FileType + '&modelid=' + ModelId + '&nodeid=' + NodeId + '&productid=' + ProductId
, accept: 'file'
, multiple: true
, auto: false
, bindAction: '#testListAction'
, choose: function (obj) {
var files = this.files = obj.pushFile(); //將每次選擇的文件追加到文件隊列
//讀取本地文件
obj.preview(function (index, file, result) {
var tr = $(['<tr id="upload-' + index + '">'
, '<td>' + file.name + '</td>'
, '<td>' + (file.size / 1014).toFixed(1) + 'kb</td>'
, '<td>等待上傳</td>'
, '<td>'
, '<button class="layui-btn layui-btn-mini demo-reload layui-hide">重傳</button>'
, '<button class="layui-btn layui-btn-mini layui-btn-danger demo-delete">刪除</button>'
, '</td>'
, '</tr>'].join(''));
//單個重傳
tr.find('.demo-reload').on('click', function () {
obj.upload(index, file);
});
//刪除
tr.find('.demo-delete').on('click', function () {
delete files[index]; //刪除對應的文件
tr.remove();
uploadListIns.config.elem.next()[0].value = ''; //清空 input file 值,以免刪除後出現同名文件不可選
});
demoListView.append(tr);
});
}
, done: function (res, index, upload) {
if (res.Status == "success") {
var tr = demoListView.find('tr#upload-' + index), tds = tr.children();
tds.eq(2).html('<span style="color: #5FB878;">上傳成功</span>');
return null;
} else {
if (res.Message == "文件已存在") {
var tr = demoListView.find('tr#upload-' + index), tds = tr.children();
tds.eq(2).html('<span style="color: #5FB878;">上傳失敗,文件已存在</span>');
return null;
} else {
this.error(index, upload);
}
}
}
, error: function (index, upload) {
var tr = demoListView.find('tr#upload-' + index)
, tds = tr.children();
tds.eq(2).html('<span style="color: #FF5722;">上傳失敗</span>');
tds.eq(3).find('.demo-reload').removeClass('layui-hide'); //顯示重傳
}
});
});
function heightTiao(nameid) {
var oIframe = window.top.document.getElementById(nameid);
var oBody = document.getElementsByTagName("body")[0];
oIframe.style.height = oBody.offsetHeight + 40 + 'px';
};
</script>
</body>
</html>
C#後端接收代碼
HttpFileCollection hfc = System.Web.HttpContext.Current.Request.Files;
string str1 = AppDomain.CurrentDomain.SetupInformation.ApplicationBase;
string imgPath = "";
string fileName = "";
fileName = hfc[0].FileName;
imgPath = Server.MapPath("~/bin/" + fileName);
imgPath = Server.MapPath("~/bin/" + modelId + "/" + productid + "/" + nodeid + "/" + filetype + "/" + fileName);
hfc[0].SaveAs(imgPath);
return Content(new AjaxResult { Status = ResultType.success, Message = "執行成功" }.ToJson());
具體使用過程中需要注意的是
auto: false
bindAction: ‘#testListAction’
這兩個參數主要是設定爲當你選擇文件時不上傳文件,而指定某個按鈕來執行上傳的動作
假設需要選擇文件時則執行上傳動作,只需要把auto設爲true,並且去掉bindAction這個參數
其它參數可參照layui官網文檔
上傳文件需要判斷的很多,只是簡單記錄個例子方便自己以後的使用
有所不足,麻煩大家指教。互相交流