Ajax--FormData实现二进制文件上传

Posted 初铮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Ajax--FormData实现二进制文件上传相关的知识,希望对你有一定的参考价值。

*
FormData二进制文件上传
<input type="file" name="file"/>
var file=document.getElementById(\'file\');
//当用户选择文件的时候
file.onchange=function(){
//创建空表单对象
var formdata=new FormData();
//将用户选择的二进制文件追加到表单对象中
formData.append(\'attrName\',this.files[0]);
//配置ajax对象,请求方式必须为post
xhr.open(\'post\',\'http://localhost:3000/formDataFile\');
xhr.send(formData);
}

*

//FormData文件上传进度展示

//当用户选择文件的时候
file.onchange=function(){
//文件上传过程中持续触发onprogress事件
xhr.upload.onprogress=function(ev){
//当前上传文件大小/文件总大小 再将结果转换为百分数
//将结果赋值给进度条的宽度属性
bar.style.width=(ev.load/ev.total)*100+"%";
}
}
*
//FormData文件上传图片即时预览
在我们将图片上传到服务器端以后,服务器通常都会将图片地址做为响应数据传递到客户端
客户端可以从响应数据中获取图片地址,然后将图片再显示再页面中。

.html

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4     <meta charset="utf-8">
 5     <title>07FormData实现二进制文件上传</title>
 6     <link rel="stylesheet" type="text/css" href="/assets/bootstrap/dist/css/bootstrap.min.css">
 7     <style type="text/css">
 8         .container{
 9             padding:-top:60px;
10         }
11         .padding{
12             padding:5px 0 20px 0;
13         }
14         .progress{
15             background-color: gray;
16         }
17         .progress-bar{
18             background-color: skyblue;
19             text-align: center;
20         }
21     </style>
22 </head>
23 <body class="test">
24     <div class="container">
25         <div class=form-group>
26             <label>请选择文件</label>
27             <input type="file" id="file">
28             <div class="padding" id="box">
29                 <img src="" class="img-round img-responsive" id="img">
30             </div>
31             <div class="progress">
32                 <div class="progress-bar" style="width:0%;" id="bar">0%</div>
33             </div>
34         </div>    
35     </div>
36     <script type="text/javascript">
37         //获取文件选择控件
38         var file=document.getElementById(\'file\');
39         //获取进度条元素
40         var bar=document.getElementById("bar");
41         var img=document.getElementById("img");
42         var box=document.getElementById("box");
43         //为用户选择控件添加onchange事件
44         //在用户选择文件时触发
45         file.onchange=function(){
46             //创建空的FormData的表单对象
47             var formData=new FormData();
48             //将用户选择的文件追加到formData表单对象中
49             formData.append(\'attrName\',this.files[0]);
50             //发送ajax请求
51             var xhr=new XMLHttpRequest();
52             xhr.open(\'post\',\'http://localhost:3000/upload\');
53             //在文件上传的过程中持续触发
54             xhr.upload.onprogress=function(ev){
55                 //ev.loaded  文件已经上传了多少
56                 //ev.total   上传文件的总大小
57                 var result=parseInt((ev.loaded/ev.total)*100)+"%";
58                 //设置进度条宽度
59                 bar.style.width=result;
60                 //将百分比显示在进度条中
61                 bar.innerHTML=result;
62                 console.log(ev)
63             };
64             xhr.send(formData);
65             xhr.onload=function(){
66                 if(xhr.status==200){
67                     //console.log(xhr.responseText);
68                     var result=JSON.parse(xhr.responseText);
69                     //动态创建img表单
70                    // var img2=document.createElement("img");
71                     //给图片标签设置src属性
72                     console.log(result.path);
73                     img.src=result.path;
74                    // img2.src=result.path;
75                     //当图片加载完成以后
76                    // img2.onload=function(){
77                     //将图片显示在页面中
78                     // box.appendChild(img2);
79                     //}
80                 }
81             }
82             
83         }
84 
85     </script>
86 
87 </body>
88 </html>

app.js

 1 app.post(\'/upload\',(req,res)=>{
 2     //创建formidable表单解析对象
 3     const form=new formidable.IncomingForm();
 4     //设置客户端上传文件的存储路径
 5     form.uploadDir=path.join(__dirname,\'public\',\'uploads\');
 6     //保留上传文件的后缀名字
 7     form.keepExtensions=true;
 8     //解析客户端传递过来的FormData对象
 9     form.parse(req,(err,fields,files)=>{
10         //将客户端传递过来的地址响应到客户端
11         console.log(files.attrName.path.split(\'public\')[1])
12         res.send({
13             path:files.attrName.path.split(\'public\')[1]
14         });
15     });
16 
17 });

运行结果:

 

以上是关于Ajax--FormData实现二进制文件上传的主要内容,如果未能解决你的问题,请参考以下文章

Ajax+formData异步文件上传

SpringBoot+ajax+formData实现图片上传和回显

ajax+FormData+javascript实现无刷新表单信息提交

BBS - 首页个人站点ORM

AJAX FormData Post - 503 服务不可用

Uncaught TypeError: Illegal invocation报错简单直接解决方案