您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
怎么在JavaScript中使用FormData类上传文件?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
案例一:xhr.upload.onprogress监控文件的上传进度,并且动态显示
<!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>
案例二:服务器端返回上传路径,供客户端预览上传的图片效果
成功预览我家耶啵的帅照
<!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] }); }) })
关于怎么在JavaScript中使用FormData类上传文件问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。