HTML5关于上传API的一些使用(中)

    上一次写了关于HTML的上传API,XMLHttpRequest2.0的上传方式,以及HTML5中上传之前本地的预览,包括对于图片以及部分信息的预
览。这次我们就讲下HTML5中关于上传的一些各种个性化需求的处理,主要包括实时进度条,上传速度的实时显示等。

关于上传事件

首先要做到实时进度条这种需求,首先我们需要得到关于上传的各种事件,这些事件大部分都是在XMLHttpRequest这个对象下面:

  • progress事件:上传进度事件。
  • load事件:传输成功完成。
  • abort事件:传输被用户取消。
  • error事件:传输中出现错误。
  • loadstart事件:传输开始。
  • loadEnd事件:传输结束,但是不知道成功还是失败。

其中progress事件分为上传和下载两种情况,上传的时候progress事件实际上是在XMLHttpRequest.upload对象下面,而下载的时候属于XMLHttpRequest对象

关于实时进度条

我们可以在上篇中的方法基础上进行扩展来写实时进度条的方法,

var xhr=new XMLHttpRequest();
var formData=new FormData();
formData.append(‘name‘,"Jack");
formData.append(‘uid‘,666666);
xhr.open("post",url);
xhr.send(formData);
//上传中
xhr.upload.addEventListener("progress", uploadProgress, false);
//上传成功
xhr.addEventListener("load", uploadComplete, false);
//上传出错
xhr.addEventListener("error", uploadFailed, false);
//上传取消
xhr.addEventListener("abort", uploadCanceled, false);

而上传事件还给我们提供了下面这些数据

  • total – 文件大小
  • loaded – 已上传的大小
  • lengthComputable – 进度是否可计算

通过上面这些事件以及属性就可以很轻易的写出进度条。

function uploadProgress(evt){   //evt 上传事件中返回的数据
    if (evt.lengthComputable) { //判断进度是否可以计算
        var percentComplete = Math.round(evt.loaded * 100 / evt.total); //对进度进行计算并且格式化
        document.getElementById(‘progressNumber‘).innerHTML = percentComplete.toString() + ‘%‘;     //输出100%
    }else {
        document.getElementById(‘progressNumber‘).innerHTML = ‘unable to compute‘;
    }
}

上面这个方法是直接在某个div中直接显示百分比的数字,假如我们需要做进度条也很简单,可以添加一个标签,默认宽度为0,然后在uploadProgress方法中动态更改标签的宽度,单位为百分比,而值就是percentComplete,这样可以在上传的过程当中得到一个完整的进度条。

而当我们文件上传完毕之后可以在load事件中绑定的uploadComplete方法中去做一些css等UI的修改。

关于实时上传速度的显示

现在进度条有了,可是我们还想知道速度是多少应该怎么办呢。

可以通过计算的方法获取其上传的速度,我们在progress事件中是知道已上传的文件大小的,那我们在uploadProgress方法中没过1秒都去计算一下这一次和上一次的loaded大小就可以知道其每秒的上传速度。从而在页面上实时的更新当前的上传速度了。

代码如下

// currentLoadedBytesb本次上传的数据总量,
// lastLoadedBytes 上一次上传的数据总量
// oldObjUploadBits旧的上传速度
var currentLoadedBytes,lastLoadedBytes,oldObjUploadBits;
timer = setInterval(
    function () {
        var bytesCount = currentLoadedBytes - lastLoadedBytes;
        if (bytesCount !== 0) {
            var speed = ConvertBytesUnit(bytesCount);
            $(obj).html("上传速度:" + speed.number + speed.unit + "/s");
        } else {
            $(obj).html(oldObjUploadBits);
        }
        oldObjUploadBits = $(obj).html();
        lastLoadedBytes = currentLoadedBytes;
    }
, 1000)   

function ConvertBytesUnit(size){
    if (size < 0) size = 0;
    var result = {};
    if (size > 1024 * 1024) {
        result.number = (size / (1024 * 1024)).toFixed(2);
        result.unit = "MB";
    } else if (size > 1024 ) {
        result.number = (size / 1024).toFixed(2);
        result.unit = "KB";
    } else {
        result.number = size.toFixed(2);
        result.unit = "B";
    }
    return (result);
}    

通过上面的方法就可以获得每一秒具体的上传速度了。

另外XMLHttpRequest2.0可以实现的功能其实很多,另外还可以实现断点续传,以及分片上传等更高级的功能。我们留在下一篇再来说。

时间: 2024-10-10 06:55:32

HTML5关于上传API的一些使用(中)的相关文章

HTML5关于上传API的一些使用(上)

HTML5提供了很多有用的API,其中就包括上传的API,XMLHttpRequest2.0,在HTML5时代之前,需要进行二进制的上传一般都会才用flash的方案,但是当XMLHttpRequest2.0出来之后,完全可以使用HTML5的上传解决方案,能够非常方便的进行二进制上传进度的显示,上传图片的本地预览,甚至可以做到断点续传,分片上传,多文件上传等各种复杂的底层功能. 首先回顾一下XMLHttpRequest1.0的传输过程 关于XMLHttpRequest 初始化XMLHttpRequ

AJAX文件上传实践与分析,带HTML5文件上传API。

对于HTML5已经支持AJAX文件上传了,但如果需要兼容的话还是得用一点小技巧的,HTML5等等介绍,先来看看以前我们是怎么写的. 网上可能会有一些叫AJAX文件上传插件,但在AJAX2.0之前是不可能实现的,因为浏览器的原因,AJAX根本获取不了文件信息,当然这里并不是说就不能文件上传了,只是说在AJAX2.0之前所谓的AJAX文件上传都是假冒的,核心更本没有用AJAX,而是利用iframe实现的,下面我们来看看如何利用iframe实现页面无刷新上传文件. iframe无刷新上传文件版. ht

HTML5关于上传API的一些使用(下)

通过前面两篇的分享,我们已经搞定了单个文件的普通的上传,包括文件预览,图片预览,上传速度等前端界面的显示,这次我们来谈谈关于>XMLHttpRequest2.0在界面之后假如才用分片上传能做到一些什么功能 关于分片上传 为什么要使用分片上传? 考虑如下场景,假如用户需要在一个视频分享社区上传一部.avi的视频文件进行分享,大小在2G以上,这个时候用户假如在上传的过程当中,发生了宽带掉线,不小心关闭了浏览器等这种意外的事情,用户这个时候除了重传整个文件以外,没有其他更好的选择,可能用户就不会考虑再

html5 图片上传,支持图片预览、压缩、及进度显示,兼容IE6+及标准浏览器

原文:html5 图片上传,支持图片预览.压缩.及进度显示,兼容IE6+及标准浏览器 以前写过上传组件,见 打造 html5 文件上传组件,实现进度显示及拖拽上传,兼容IE6+及其它标准浏览器,对付一般的上传没有问题,不过如果是上传图片,且需要预览的话,就力有不逮了,趁着闲暇时间,给上传组件添加了单独的图片上传UI,支持图片预览和缩放(通过调整图片的大小以实现图片压缩). 上传组件特点 轻量级,不依赖任何JS库,核心代码(Q.Uploader.js)仅约700行,min版本加起来不到12KB 纯

基于HT for Web矢量实现HTML5文件上传进度条

在HTML中,在文件上传的过程中,很多情况都是没有任何的提示,这在体验上很不好,用户都不知道到时有没有在上传.上传成功了没有,所以今天给大家介绍的内容是通过HT for Web矢量来实现HTML5文件上传进度条,矢量在<矢量Chart图表嵌入HTML5网络拓扑图的应用>一文中已经讲述了关于setCompType()方法的应用,今天我们用setImage()方法充分利用系统中定义好的矢量资源来实现文件上传进度条,我们先来看下效果图: 从效果图可以看到,向服务器上传了一个mp4文件,并在最下方显示

HTML5 文件上传

HTML5 文件上传 1 filelist对象与file对象: 1 <input type="file" id="file" multiple> //multiple可上传多个文件 2 <input type="button" onclick="showFileName()" value="文件上传"> 3 <script> 4 function showFileName

腾讯云cos对象存储服务文件上传api就是一个大坑

一.介绍 对象存储服务(Cloud Object Service)是基于腾讯多年海量服务经验,对外提供的可靠.安全.易用的海量存储服务.提供多样化接入方式,以及全国部署的上传加速集群,可以无缝衔接CDN进行加速下载. 二.cos 文件上传api源码 /** * 单个文件上传,适用于小文件 * * @param bucketName * bucket名称 * @param remotePath * 远程文件路径 * @param localPath * 本地文件路径 * @return 服务器端返

HTML5文件上传组件美化jQuery插件

简要教程 jQuery.filer是一款简单的HTML5文件上传组件美化jQuery插件.它能够完成单文件和多文件的上传,支持文件的拖拽,支持不同的文件格式校验,支持缩略图和图标等,是一款非常实用的文件上传插件.它的特点还有: 对文件上传File Input组件进行美化 支持多文件上传 支持校验文件:大小,扩展名等 支持创建文件的缩略图 每种类型的文件可以自定义图标 可以为缩略图,图标和input自定义模板和主题 可以移出已选择的文件 可以从剪切板粘贴图片 所有的图标在一个字体文件中 支持文件拖

html5文件上传

<!DOCTYPE html><html><head> <title>Html5 Ajax 上传文件</title></head><body> <progress id="progressBar" value="0" max="100"> </progress> <span id="percentage">&