JS中FormData类实现文件上传


Posted in Javascript onMarch 27, 2020

本文实例为大家分享了JS中FormData类实现文件上传的具体代码,供大家参考,具体内容如下

上篇文章讲到了FormReader类实现文件上传,但是那是HTML5的新特性,在不支持H5的浏览器上则无法使用。这次介绍一个JS的普通类FormData,在不支持H5浏览器环境下也可以文件上传和预览,并且还能监控上传进度。

案例一:xhr.upload.onprogress监控文件的上传进度,并且动态显示

JS中FormData类实现文件上传

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <title>Document</title>
 <style>
 .progress {
 width: 100px;
 height: 10px;
 background-color: #eee;
 }
 .progress-bar {
 width: 0;
 height: 10px;
 background-color: blue;
 }
 </style>
</head>
<body>
 <form action="" id="form">
 <input type="file" name="file" id="file">
 </form>
 <div class="progress">
 <div class="progress-bar" id="bar"></div>
 </div>
 <script>
 var file = document.getElementById("file");
 var bar = document.getElementById("bar");
 file.onchange = function () {
 var formData = new FormData();
 // 上传的文件
 formData.append('attrName', this.files[0]);

 var xhr = new XMLHttpRequest();
 xhr.open("post", "/upload");
 // xhr.upload.onprogress监听上传进度
 xhr.upload.onprogress = function (ev) {
 // ev.loaded表示上传了多少,ev.total表示文件的总大小
 var result = (ev.loaded / ev.total * 100).toFixed(2) + '%';
 // result为进度百分比
 bar.style.width = result;
 bar.innerHTML = result;
 }
 xhr.send(formData);
 xhr.onload = function () {
 if(xhr.status == 200) {
  console.log(xhr.responseText);
 }
 }
 }
 </script>
</body>
</html>

案例二:服务器端返回上传路径,供客户端预览上传的图片效果

成功预览我家耶啵的帅照

JS中FormData类实现文件上传

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <title>Document</title>
 <style>
 .progress {
 display: inline-block;
 width: 600px;
 height: 20px;
 border-radius: 5px;
 background-color: #eee;
 }
 .progress-bar {
 width: 0;
 height: 20px;
 background-color: orange;
 border-radius: 5px;
 font-size: 16px;
 text-align: center;
 color: #fff;
 }
 </style>
</head>
<body>
 <form action="" id="form">
 <input type="file" name="file" id="file">
 <div class="progress">
 <div class="progress-bar" id="bar"></div>
 </div>
 </form>
 
 <div id="box"></div>
 <script>
 var file = document.getElementById("file");
 var bar = document.getElementById("bar");
 var box = document.getElementById("box");
 file.onchange = function () {
 var formData = new FormData();
 // 上传的文件
 formData.append('attrName', this.files[0]);

 var xhr = new XMLHttpRequest();
 xhr.open("post", "/upload");
 xhr.upload.onprogress = function (ev) {
 // ev.loaded表示上传了多少,ev.total表示文件的总大小
 var result = (ev.loaded / ev.total * 100).toFixed(2) + '%';
 // result为进度百分比
 bar.style.width = result;
 bar.innerHTML = result;
 }
 xhr.send(formData);
 xhr.onload = function () {
 if(xhr.status == 200) {
  var result = JSON.parse(xhr.responseText);
  var img = document.createElement('img');
  img.src = result.path;
  // 图片加载完成在进行显示,否则用户会看到图片的加载过程,效果不好
  img.onload = function () {
  box.appendChild(img);
  }
 }
 }
 }
 </script>
</body>
</html>

nodejs服务器端的部分代码:

app.post('/upload', (req, res) => {
 // 创建formidable表单解析对象
 const form = new formidable.IncomingForm();
 // 上传文件的路径
 form.uploadDir = path.join(__dirname, 'public', 'uploads');
 // 上传文件的后缀名保留
 form.keepExtensions = true;
 // 解析客户端传递过来的FormData对象
 form.parse(req, (err, fileds, files) => {
 // 将文件的地址扒出来以json对象的形式返回给客户端
 res.send({
 path: files.attrName.path.split('public')[1]
 });
 })
})

更多精彩内容请参考专题《ajax上传技术汇总》,《javascript文件上传操作汇总》和《jQuery上传操作汇总》进行学习。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
用js统计用户下载网页所需时间的脚本
Oct 15 Javascript
jsTree树控件(基于jQuery, 超强悍)[推荐]
Sep 01 Javascript
JS控制图片翻转示例代码(兼容firefox,ie,chrome)
Dec 19 Javascript
浅谈JavaScript正则表达式分组匹配
Apr 10 Javascript
javascript中substring()、substr()、slice()的区别
Aug 30 Javascript
AngularJS中的JSONP实例解析
Dec 01 Javascript
微信小程序 封装http请求实例详解
Jan 16 Javascript
原生js实现倒计时--2018
Feb 21 Javascript
jQuery选择器特殊字符与属性空格问题
Aug 14 jQuery
jQuery实现菜单栏导航效果
Aug 15 jQuery
详解解决小程序中webview页面多层history返回问题
Aug 20 Javascript
vue如何使用async、await实现同步请求
Dec 09 Javascript
JS中FileReader类实现文件上传及时预览功能
Mar 27 #Javascript
js、jquery实现列表模糊搜索功能过程解析
Mar 27 #jQuery
开发Node CLI构建微信小程序脚手架的示例
Mar 27 #Javascript
微信小程序间使用navigator跳转传值问题实例分析
Mar 27 #Javascript
vue跳转页面的几种方法(推荐)
Mar 26 #Javascript
Vue项目页面跳转时浏览器窗口上方显示进度条功能
Mar 26 #Javascript
JavaScript定时器使用方法详解
Mar 26 #Javascript
You might like
VIM中设置php自动缩进为4个空格的方法详解
2013/06/14 PHP
编译php 5.2.14+fpm+memcached(具体操作详解)
2013/06/18 PHP
ThinkPHP3.1新特性之对页面压缩输出的支持
2014/06/19 PHP
Laravel中日期时间处理包Carbon的简单使用
2017/09/21 PHP
JQuery的Alert消息框插件使用介绍
2010/10/09 Javascript
ExtJS下书写动态生成的xml(兼容火狐)
2013/04/02 Javascript
js在IE与firefox的差异集锦
2014/11/11 Javascript
JavaScript数据库TaffyDB用法实例分析
2015/07/27 Javascript
javascript实现的淘宝旅行通用日历组件用法实例
2015/08/03 Javascript
angular4 JavaScript内存溢出问题
2018/03/06 Javascript
vue+axios 前端实现的常用拦截的代码示例
2018/08/23 Javascript
微信小程序非swiper组件实现的自定义伪3D轮播图效果示例
2018/12/11 Javascript
javascript实现移动端触屏拖拽功能
2020/07/29 Javascript
在HTML中使用JavaScript的两种方法
2020/12/24 Javascript
Python中文编码那些事
2014/06/25 Python
使用Python简单的实现树莓派的WEB控制
2016/02/18 Python
一步步教你用Python实现2048小游戏
2017/01/19 Python
Django中login_required装饰器的深入介绍
2017/11/24 Python
Python函数参数操作详解
2018/08/03 Python
Python closure闭包解释及其注意点详解
2019/08/28 Python
快速解决docker-py api版本不兼容的问题
2019/08/30 Python
pytorch 改变tensor尺寸的实现
2020/01/03 Python
Python中url标签使用知识点总结
2020/01/16 Python
django admin 添加自定义链接方式
2020/03/11 Python
Python3+selenium实现cookie免密登录的示例代码
2020/03/18 Python
Windows+Anaconda3+PyTorch+PyCharm的安装教程图文详解
2020/04/03 Python
详解Pycharm与anaconda安装配置指南
2020/08/25 Python
使用canvas对多图片拼合并导出图片的方法
2018/08/28 HTML / CSS
请说出你所知道的线程同步的方法
2013/04/19 面试题
幼师岗位求职简历的自荐信格式
2013/09/21 职场文书
中医临床专业自我鉴定范文
2014/01/15 职场文书
可贵的沉默教学反思
2014/02/06 职场文书
北京奥运会口号
2014/06/21 职场文书
企业安全生产目标责任书
2014/07/23 职场文书
2015年员工工作总结范文
2015/04/08 职场文书
JavaScript 防篡改对象的用法示例
2021/04/24 Javascript