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 相关文章推荐
c#和Javascript操作同一json对象的实现代码
Jan 17 Javascript
javascript查找字符串中出现最多的字符和次数的小例子
Oct 29 Javascript
调试JavaScript中正则表达式中遇到的问题
Jan 27 Javascript
javascript动画之模拟拖拽效果篇
Sep 26 Javascript
jQuery EasyUI 获取tabs的实例解析
Dec 06 Javascript
基于angular-utils-ui-breadcrumbs使用心得(分享)
Nov 03 Javascript
angularjs 获取默认选中的单选按钮的value方法
Feb 28 Javascript
JS实现模糊查询带下拉匹配效果
Jun 21 Javascript
layui点击导航栏刷新tab页的示例代码
Aug 14 Javascript
详解用JS添加和删除class类名
Mar 25 Javascript
Vue项目部署的实现(阿里云+Nginx代理+PM2)
Mar 26 Javascript
vue通过v-html指令渲染的富文本无法修改样式的解决方案
May 20 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
php 函数使用方法与函数定义方法
2010/05/09 PHP
php连接odbc数据源并保存与查询数据的方法
2014/12/24 PHP
php中get_defined_constants函数用法实例分析
2015/05/12 PHP
Yii框架组件和事件行为管理详解
2016/05/20 PHP
JavaScript打印iframe内容示例代码
2013/08/20 Javascript
javascript陷阱 一不小心你就中招了(字符运算)
2013/11/10 Javascript
js操作输入框中选择内容兼容IE及其他主流浏览器
2014/04/22 Javascript
JS实现鼠标箭头变成一个燃烧烛光效果的方法
2015/02/28 Javascript
jQuery学习笔记之入门
2016/12/14 Javascript
浅谈javascript alert和confirm的美化
2016/12/15 Javascript
JS利用cookies设置每隔24小时弹出框
2017/04/20 Javascript
十个免费的web前端开发工具详细整理
2017/09/18 Javascript
如何把vuejs打包出来的文件整合到springboot里
2018/07/26 Javascript
Node.js实现一个HTTP服务器的方法示例
2019/05/13 Javascript
BootStrap前端框架使用方法详解
2020/02/26 Javascript
JavaScript实现捕获鼠标坐标
2020/04/12 Javascript
vuex中遇到的坑,vuex数据改变,组件中页面不渲染操作
2020/11/16 Javascript
[59:48]DOTA2-DPC中国联赛 正赛 VG vs Magma BO3 第一场 1月26日
2021/03/11 DOTA
python将字符串转换成数组的方法
2015/04/29 Python
Python 常用的安装Module方式汇总
2017/05/06 Python
python实现微信机器人: 登录微信、消息接收、自动回复功能
2019/04/29 Python
python set集合使用方法解析
2019/11/05 Python
Python3实现发送邮件和发送短信验证码功能
2020/01/07 Python
tensorflow使用L2 regularization正则化修正overfitting过拟合方式
2020/05/22 Python
python如何建立全零数组
2020/07/19 Python
python3爬虫中多线程的优势总结
2020/11/24 Python
CSS3 icon font完全指南(CSS3 font 会取代icon图标)
2013/01/06 HTML / CSS
利用CSS3的border-radius绘制太极及爱心图案示例
2016/05/17 HTML / CSS
Hotels.com越南:酒店预订
2019/10/29 全球购物
餐饮管理自我介绍信
2014/01/15 职场文书
物流业务员岗位职责
2014/02/08 职场文书
数控技校生自我鉴定
2014/04/19 职场文书
食品质量与安全专业毕业生求职信
2014/08/11 职场文书
房地产财务经理岗位职责
2015/04/08 职场文书
Python机器学习实战之k-近邻算法的实现
2021/11/27 Python
Android studio 简单计算器的编写
2022/05/20 Java/Android