JS中FormData类实现文件上传

作者:爱玲姐姐 时间:2024-04-10 10:50:10 

本文实例为大家分享了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上传操作汇总》进行学习。

来源:https://blog.csdn.net/jal517486222/article/details/104769041

标签:js,FormData,文件上传
0
投稿

猜你喜欢

  • 利用Vscode进行Python开发环境配置的步骤

    2023-04-18 09:06:46
  • Yii2 rbac权限控制操作步骤实例教程

    2024-05-22 10:02:18
  • python基于C/S模式实现聊天室功能

    2021-05-01 04:17:53
  • Django静态文件加载失败解决方案

    2021-05-25 19:40:47
  • php之app消息推送案例教程

    2023-06-15 00:42:02
  • python中黄金分割法实现方法

    2022-05-15 01:45:24
  • Jupyter notebook 远程配置及SSL加密教程

    2021-06-24 07:15:06
  • MySql InnoDB存储引擎之Buffer Pool运行原理讲解

    2024-01-27 01:46:50
  • 如何从SQL数据库中调用图片?

    2009-11-15 19:59:00
  • MySQL数据库root权限丢失解决方案

    2008-07-13 13:59:00
  • pythotn条件分支与循环详解

    2021-12-02 12:20:08
  • JS统计Flash被网友点击过的代码

    2024-05-03 15:06:18
  • ASP函数指针试探-GetRef

    2009-10-12 12:39:00
  • Mysql导入导出时遇到的问题解决

    2024-01-22 02:28:06
  • 如何显示数据库里的图片?

    2010-06-08 09:36:00
  • Python bsddb模块操作Berkeley DB数据库介绍

    2024-01-18 05:32:02
  • python函数超时自动退出的实操方法

    2021-09-11 07:07:45
  • SQLServer 附加数据库后出现只读或失败的解决方法

    2024-01-18 11:29:23
  • 详解MySQL中的pid与socket

    2024-01-26 15:07:56
  • django框架模板中定义变量(set variable in django template)的方法分析

    2021-11-18 03:28:04
  • asp之家 网络编程 m.aspxhome.com