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


Posted in HTML / CSS onAugust 30, 2012

这里我们是结合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
HTML / CSS 相关文章推荐
使用css3匹配手机屏幕横竖状态
Jan 27 HTML / CSS
CSS3中线性颜色渐变的一些实现方法
Jul 14 HTML / CSS
基于CSS3实现立方体自转效果
Mar 01 HTML / CSS
浅析CSS3中鲜为人知的属性:-webkit-tap-highlight-color
Jan 12 HTML / CSS
利用Bootstrap实现漂亮简洁的CSS3价格表实例源码
Mar 02 HTML / CSS
利用css3如何设置没有上下边的列表间隔线
Jul 03 HTML / CSS
HTML5+CSS3绘制锯齿状的矩形
Mar 01 HTML / CSS
h5调用摄像头的实现方法
Jun 01 HTML / CSS
HTML5视频播放插件 video.js介绍
Sep 29 HTML / CSS
canvas中普通动效与粒子动效的实现代码示例
Jan 03 HTML / CSS
详解HTML5 Canvas标签及基本使用
Jan 10 HTML / CSS
Html5定位终极解决方案
Feb 05 HTML / CSS
input元素的url类型和email类型简介
Jul 11 #HTML / CSS
HTML5安全介绍之内容安全策略(CSP)简介
Jul 10 #HTML / CSS
开发人员所需要知道的HTML5性能分析面面观
Jul 05 #HTML / CSS
关于HTML5的22个初级技巧(图文教程)
Jun 21 #HTML / CSS
关于HTML5的安全问题开发人员需要牢记的
Jun 21 #HTML / CSS
HTML5 对各个标签的定义与规定:body的介绍
Jun 21 #HTML / CSS
网易微博Web App用HTML5开发的过程介绍
Jun 13 #HTML / CSS
You might like
PHP的FTP学习(一)[转自奥索]
2006/10/09 PHP
PHP连接和操作MySQL数据库基础教程
2014/09/29 PHP
php实现二进制和文本相互转换的方法
2015/04/18 PHP
PHP通过curl获取接口URL的数据方法
2018/05/31 PHP
jquery tools 系列 scrollable学习
2009/09/06 Javascript
将两个div左右并列显示并实现点击标题切换内容
2013/10/22 Javascript
JS+CSS实现仿触屏手机拨号盘界面及功能模拟完整实例
2015/05/16 Javascript
使用jQuery mobile库检测url绝对地址和相对地址的方法
2015/12/04 Javascript
Bootstrap与KnockoutJs相结合实现分页效果实例详解
2016/05/03 Javascript
js实现图片缓慢放大缩小效果
2016/08/02 Javascript
JS出现失效的情况总结
2017/01/20 Javascript
如何使用bootstrap框架 bootstrap入门必看!
2017/04/13 Javascript
vue slot与传参实例代码讲解
2019/04/28 Javascript
JavaScript中的垃圾回收与内存泄漏示例详解
2019/05/02 Javascript
通过图带你深入了解vue的响应式原理
2019/06/21 Javascript
微信小程序Echarts图表组件使用方法详解
2019/06/25 Javascript
微信小程序基于Taro的分享图片功能实践详解
2019/07/12 Javascript
layui添加动态菜单与选项卡
2019/07/26 Javascript
[01:44]剑指西雅图 展望TI之CIS战队专访
2014/06/25 DOTA
python 禁止函数修改列表的实现方法
2017/08/03 Python
python生成随机图形验证码详解
2017/11/08 Python
Python基于opencv的图像压缩算法实例分析
2018/05/03 Python
python 读取修改pcap包的例子
2019/07/23 Python
PyQt5高级界面控件之QTableWidget的具体使用方法
2020/02/23 Python
python访问hdfs的操作
2020/06/06 Python
celery在python爬虫中定时操作实例讲解
2020/11/27 Python
车辆维修工自我评价怎么写
2013/09/20 职场文书
魅力教师事迹材料
2014/01/10 职场文书
档案接收函
2014/01/13 职场文书
《寓言两则》教学反思
2014/02/27 职场文书
关于学习的决心书
2015/02/05 职场文书
情人节活动总结范文
2015/02/05 职场文书
公司开业主持词
2015/07/02 职场文书
校园之声广播稿
2015/08/18 职场文书
2016年第104个国际护士节活动总结
2016/04/06 职场文书
Go语言特点及基本数据类型使用详解
2022/03/21 Golang