JS中FormData类实现文件上传

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

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

JS中FormData类实现文件上传

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta 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=""> <input type="file"> </form> <div> <div></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 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=""> <input type="file"> <div> <div></div> </div> </form> <div></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] }); }) })

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/916a0e4bd63a7bc7512c7671ce2c2520.html