Ajax 文件上傳進(jìn)度監(jiān)聽之upload.onprogress案例詳解
$.ajax實(shí)現(xiàn)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <meta http-equiv="X-UA-Compatible" content="ie=edge" /> <title>Document</title> <script src="./libs/jquery/jquery.js"></script> <style> div { width: 0%; height: 20px; background-color: #f00; /* transition: all 0.2s; */ } </style> </head> <body> <div></div> <input type="file" /> <script> $(function() { // 用戶選擇好文件之后單擊彈出層的“打開”按鈕的觸發(fā)事件是:change $('input').on('change', function() { // 1.收集文件數(shù)據(jù) let myfile = $('input')[0].files[0] let formdata = new FormData() formdata.append('file_data', myfile) // 2.發(fā)起ajax請求 $.ajax({ url: 'http://127.0.0.1:3001/uploadFile', type: 'post', data: formdata, processData: false, contentType: false, xhr: function() { let newxhr = new XMLHttpRequest() // 添加文件上傳的監(jiān)聽 // onprogress:進(jìn)度監(jiān)聽事件,只要上傳文件的進(jìn)度發(fā)生了變化,就會(huì)自動(dòng)的觸發(fā)這個(gè)事件 newxhr.upload.onprogress = function(e) { console.log(e) let percent = (e.loaded / e.total) * 100 + '%' $('div').css('width', percent) } return newxhr }, success: function(res) { console.log(res) }, dataType: 'json' }) }) }) </script> </body> </html>
原生實(shí)現(xiàn):
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <meta http-equiv="X-UA-Compatible" content="ie=edge" /> <title>Document</title> <script src="./libs/jquery/jquery.js"></script> <style> div { width: 0%; height: 20px; background-color: #f00; /* transition: all 0.2s; */ } </style> </head> <body> <div></div> <input type="file" /> <script> $(function() { // 用戶選擇好文件之后單擊彈出層的“打開”按鈕的觸發(fā)事件是:change $('input').on('change', function() { // 1.收集文件數(shù)據(jù) let myfile = $('input')[0].files[0] let formdata = new FormData() formdata.append('file_data', myfile) let xhr = new XMLHttpRequest() xhr.open('post', 'http://127.0.0.1:3001/uploadFile') // 細(xì)節(jié)1:文件上傳,如果使用fromdata,則不要設(shè)置請求頭 xhr.upload.onprogress = function(e) { console.log(e) let percent = (e.loaded / e.total) * 100 + '%' $('div').css('width', percent) } // 細(xì)節(jié)2:send中可以直接傳遞formdata xhr.send(formdata) }) }) </script> </body> </html>
到此這篇關(guān)于Ajax 文件上傳進(jìn)度監(jiān)聽之upload.onprogress案例詳解的文章就介紹到這了,更多相關(guān)Ajax 文件上傳進(jìn)度監(jiān)聽之upload.onprogress內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js將圖片轉(zhuǎn)base64的兩種實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于js將圖片轉(zhuǎn)base64的兩種實(shí)現(xiàn)方法,Base64是網(wǎng)絡(luò)上最常見的用于傳輸8Bit字節(jié)碼的編碼方式之一,Base64就是一種基于64個(gè)可打印字符來表示二進(jìn)制數(shù)據(jù)的方法,需要的朋友可以參考下2023-07-07javascript 拖動(dòng)表格行實(shí)現(xiàn)代碼
用js實(shí)現(xiàn)的拖動(dòng)表格的tr行的實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-05-05JS組件Form表單驗(yàn)證神器BootstrapValidator
做Web開發(fā)的我們,表單驗(yàn)證是再常見不過的需求了。友好的錯(cuò)誤提示能增加用戶體驗(yàn)。今天就來看看bootstrapvalidator如何使用,感興趣的小伙伴們可以參考一下2016-01-01JavaScript 函數(shù)參數(shù)是傳值(byVal)還是傳址(byRef) 分享
這篇文章主要介紹了在JS中函數(shù)參數(shù)是傳值(byVal)還是傳址(byRef)的誤區(qū)我們通過實(shí)例說明一下,有需要的朋友可以參考2013-07-07js中的面向?qū)ο笾畬ο蟪R妱?chuàng)建方法詳解
這篇文章主要介紹了js中的面向?qū)ο笾畬ο蟪R妱?chuàng)建方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了JavaScript創(chuàng)建對象的四種常用方式,需要的朋友可以參考下2019-12-12