HTML5上传文件显示进度的实现代码

2012-08-30 0 667

这里我们是结合Asp.net MVC做为服务端您也可以是其它的服务端语言。让我们看面这个片断的HTML:

复制代码代码如下:
@using (Html.BeginForm(\”Upload\”, \”Home\”, FormMethod.Post, new { enctype = \”multipart/form-data\” , id=\”form1\”}))
{
<div class=\”row\”>
<label for=\”file\”>
Upload Image:</label>
<input type=\”file\” name=\”fileToUpload\” id=\”fileToUpload\” multiple=\”multiple\” onchange=\”fileSelected();\” />
</div>
<div id=\”fileName\”>
</div>
<div id=\”fileSize\”>
</div>
<div id=\”fileType\”>
</div>
<div class=\”row\”>
<input type=\”button\” onclick=\”uploadFile()\” value=\”Upload Image\” />
</div>
<div id=\”progressNumber\”>
</div>
}

相关的Javascript是这样的:

复制代码代码如下:
function fileSelected() {
var file = document.getElementById(\’fileToUpload\’).files[0];
if (file) {
var fileSize = 0;
if (file.size > 1024 * 1024)
fileSize = (Math.round(file.size * 100 / (1024 * 1024)) / 100).toString() + \’MB\’;
else
fileSize = (Math.round(file.size * 100 / 1024) / 100).toString() + \’KB\’;
document.getElementById(\’fileName\’).innerHTML = \’Name: \’ + file.name;
document.getElementById(\’fileSize\’).innerHTML = \’Size: \’ + fileSize;
document.getElementById(\’fileType\’).innerHTML = \’Type: \’ + file.type;
}
}
function uploadFile() {
var fd = new FormData();
fd.append(\”fileToUpload\”, document.getElementById(\’fileToUpload\’).files[0]);
var xhr = new XMLHttpRequest();
xhr.upload.addEventListener(\”progress\”, uploadProgress, false);
xhr.addEventListener(\”load\”, uploadComplete, false);
xhr.addEventListener(\”error\”, uploadFailed, false);
xhr.addEventListener(\”abort\”, uploadCanceled, false);
xhr.open(\”POST\”, \”Home/Upload\”);
xhr.send(fd);
}
function uploadProgress(evt) {
if (evt.lengthComputable) {
var percentComplete = Math.round(evt.loaded * 100 / evt.total);
document.getElementById(\’progressNumber\’).innerHTML = percentComplete.toString() + \’%\’;
}
else {
document.getElementById(\’progressNumber\’).innerHTML = \’unable to compute\’;
}
}
function uploadComplete(evt) {
/* This event is raised when the server send back a response */
alert(evt.target.responseText);
}
function uploadFailed(evt) {
alert(\”There was an error attempting to upload the file.\”);
}
function uploadCanceled(evt) {
alert(\”The upload has been canceled by the user or the browser dropped the connection.\”);
}

上面是就原生的Javascript,在onchange事件执行fileSelected的function,在点击button执行了uploadFile的function,这里使用XMLHttpRequest实现ajax上传文件。 注意代码在Firefox 14 可以工作,IE 9目前不支持file api,可以参加这里。 服务端的代码很简单:

复制代码代码如下:
public class HomeController : Controller
{
public ActionResult Index()
{
return View();
}
/// <summary>
/// Uploads the specified files.
/// </summary>
/// <param name=\”fileToUpload\”>The files.</param>
/// <returns>ActionResult</returns>
[HttpPost]
public ActionResult Upload(HttpPostedFileBase[] fileToUpload)
{
foreach (HttpPostedFileBase file in fileToUpload)
{
string path = System.IO.Path.Combine(Server.MapPath(\”~/App_Data\”), System.IO.Path.GetFileName(file.FileName));
file.SaveAs(path);
}
ViewBag.Message = \”File(s) uploaded successfully\”;
return RedirectToAction(\”Index\”);
}
}

作者:Petter Liu
本知识来源于互联网索引,如有侵权请联系我们!

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在!
点赞 (0)

1、寻代码所有源码、代码、教程和软件均为作者提供和网友推荐收集整理而来!
2、寻代码提供的所有模块、软件等资源,均不提供任何技术服务,请知悉!
3、如您需要商用,请支持正版,寻代码网站所提供的程序仅供学习和研究使用!
4、寻代码源码不得使用于非法商业用途,不得违反国家法律。您必须在下载后24小时内删除!
5、寻代码资源每天实时更新,如遇压缩包解压密码,一律为:www.xundm.com
6、寻代码资源售价和VIP会员只是赞助,收取费用仅维持本站的日常运营所需!
7、如有链接无法下载、失效或广告,请在会员中心下工单!
如有侵犯您版权的,请来信(邮箱:[email protected])指出,本站将立即改正。

寻代码 网站制作 HTML5上传文件显示进度的实现代码 https://xundm.com/201215924.html

常见问题
  • 当然可以,寻代码每日签到奖励1寻币,推广注册奖励5寻币,只要坚持关注和推广我们站,您可以免费下载全站资源
查看详情
  • 寻代码所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 赞助VIP介绍。
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言或在会员中心直接提交工单 。
查看详情
  • 对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
查看详情

相关文章

寻代码站内服务

为您解决烦忧 - 24小时在线 专业服务