HTML5 Ajax文件上传进度条如何显示

这篇文章主要介绍了html5 ajax文件上传文件上传是如何显示的,基于原生html5实现,不需要falsh支持,进度可以自定义显示,控制灵活,对html5上传进度条感兴趣的小伙伴们可以参考一下

原本打算使用jquery插件进行异步文件上传,比如uploadfy但是需要额外的支持,也有人用iframe模仿异步上传机制,感觉都比较别扭。因为项目不考虑低版本浏览器,所以决定用html5实现。下面只是一个简单的demo,具体样式需要自己去做。
后台基于strut2进行文件上传,具体因项目而定。只是要注意设置文件大小的限制。  这个配置根据具体情况设定,超过此值会报404.
首先是上传页面,比较简单,附带了文件上者这个参数。

upload.jsp

 nbsp;html> 使用XMLHttpRequest上传文件  var xhr = new XMLHttpRequest();  //监听选择文件信息 function fileSelected() {  //HTML5文件API操作  var file = document.getElementById('fileName').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("name", document.getElementById('name').value);  fd.append("fileName", document.getElementById('fileName').files[0]);  //监听事件  xhr.upload.addEventListener("progress", uploadProgress, false);  xhr.addEventListener("load", uploadComplete, false);  xhr.addEventListener("error", uploadFailed, false);  xhr.addEventListener("abort", uploadCanceled, false);  //发送文件和表单自定义参数  xhr.open("POST", "/user/uploadifyTest_doUpload");  xhr.send(fd);  } //取消上传 function cancleUploadFile(){ xhr.abort(); }  //上传进度 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) {  //服务断接收完文件返回的结果  alert(evt.target.responseText); }  //上传失败 function uploadFailed(evt) {  alert("上传失败"); } //取消上传 function uploadCanceled(evt) {  alert("您取消了本次上传."); } 

登录后复制

fd.append(“name”, document.getElementById(‘name’).value);
fd.append(“fileName”, document.getElementById(‘fileName’).files[0]);
这两句是把文件上传到表单。因为html5支持多文件上传,所以
document.getElementById(‘fileName’).files
返回的是数组。这里只有一个文件所以取下标0的元素。

xhr.upload.addEventListener(“progress”, uploadProgress, false);

立即学习“前端免费学习笔记(深入)”;

xhr.addEventListener(“load”, uploadComplete, false);

xhr.addEventListener(“error”, uploadFailed, false);

xhr.addEventListener(“abort”, uploadCanceled, false);
这里绑定进度、上传、错误、中断的事件,提供一些交互。文件进度显示就是在progress回调中进行显示的。
然后贴上后台代码和action配置,UploadifyTestAction.java

package com.bjhit.eranges.actions.test;import java.io.File;import com.opensymphony.xwork2.ActionSupport;public class UploadifyTestAction extends ActionSupport { private static final long serialVersionUID = 837481714629791752L; private File fileName; private String name; private String responseInfo; public String doUpload() throws Exception { System.out.println(name); File myFile = fileName; System.out.println(myFile.getName()); responseInfo = "上传成功!"; return "doUpload"; } public String getName() { return name; } public void setName(String name) { this.name = name; } public File getFileName() { return fileName; } public void setFileName(File fileName) { this.fileName = fileName; } public String getResponseInfo() { return responseInfo; } public void setResponseInfo(String responseInfo) { this.responseInfo = responseInfo; }}

登录后复制

action配置

  responseInfo true 

登录后复制

以上就是本篇文章的所有内容了,希望对大家学习提供到帮助!!

相关推荐:

文件上传

文件上传

文件上传

以上就是HTML5 Ajax文件上传进度条如何显示的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3194515.html

(0)
上一篇 2025年4月1日 01:59:59
下一篇 2025年4月1日 02:00:06

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • HTML5的WEB界面中meta实列详解

    这次给大家带来html5的web界面中meta实列详解,使用html5的web界面中meta的注意事项有哪些,下面就是实战案例,一起来看一下。 注意事项 meta标签是HTML语言HEAD区的一个辅助性标签。 meta常用于定义页面的说明,…

    编程技术 2025年4月1日
    100
  • h5的定时器怎样实现进度条功能

    这次给大家带来h5的定时器怎样实现定时器功能,h5的定时器实现进度条功能的定时器有哪些,下面就是实战案例,一起来看一下。 在requestAnimationFrame出现之前,我们一般都用setTimeout和setInterval,那么h…

    编程技术 2025年4月1日
    100
  • 怎样用H5预览PDF格式的文档

    这次给大家带来怎样用h5预览pdf格式的文档,h5预览pdf格式文档的注意事项有哪些,下面就是实战案例,一起来看一下。 简介 PDF.js is a Portable 注意事项 Format (PDF) viewer that is bui…

    编程技术 2025年4月1日
    100
  • H5的拖放应该如何实现

    这次给大家带来h5的拖放应该如何实现,实现h5拖放效果应该的注意事项有哪些,下面就是实战案例,一起来看一下。 简介 拖放是一种常见的特性,即抓取对象以后拖到另一个位置。 在 HTML5 中,拖放是标准的一部分,任何元素都能够拖放。 先点击一…

    编程技术 2025年4月1日
    100
  • h5怎样通过canvas来实现滚动弹幕功能

    这次给大家带来h5怎样通过canvas来实现滚动弹幕功能,通过canvas实现滚动弹幕功能的注意事项有哪些,下面就是实战案例,一起来看一下。 最近在着手开发弹幕视频网站,通过html5中的canvas实现了弹幕的功能。 那么闲言碎语不要讲,…

    编程技术 2025年4月1日
    100
  • 用H5和C3实现简单的时钟效果

    这次给大家带来用h5和c3实现简单的时钟效果,用h5和c3实现简单的时钟效果的注意事项有哪些,下面就是实战案例,一起来看一下。 目的: 利用html5,css实现钟摆效果 知识点: 1) 利用注意事项/left/top和calc()实现元素…

    编程技术 2025年4月1日
    100
  • h5如何实现记住密码功能

    这次给大家带来h5如何实现记住密码功能,h5实现记住密码功能的注意事项有哪些,下面就是实战案例,一起来看一下。 HTML5 提供了两种在客户端存储数据的新方法: localStorage – 没有时间限制的数据存储 sessio…

    编程技术 2025年4月1日
    100
  • H5的本地存储和本地数据库详细介绍

    这次给大家带来h5的本地存储和本地数据库详细介绍,使用h5的本地存储和本地数据库的本地数据库有哪些,下面就是实战案例,一起来看一下。 本地存储 1.1 本地存储由来的背景 由于HTML4时代Cookie的大小、格式、存储数据格式等限制,网站…

    编程技术 2025年4月1日
    100
  • 怎样用h5的sse服务器发送EventSource事件

    这次给大家带来怎样用h5的sse服务器发送eventsource事件,用h5的sse服务器发送eventsource事件的事件有哪些,下面就是实战案例,一起来看一下。 前言 我前面文章讲过数据大屏,里面的数据时时事件。还有时时更新的股票数据…

    编程技术 2025年4月1日
    100
  • h5怎样实现输入框提示语+正常文本框提示语

    这次给大家带来h5怎样实现输入框提示语+正常文本框提示语,实现h5的输入框提示语+正常文本框提示语的注意事项有哪些,下面就是实战案例,一起来看一下。 登录后复制 placeholder=”  请输入用户名/手机号”;…

    编程技术 2025年4月1日
    100

发表回复

登录后才能评论