1. 基本界面
創(chuàng)新互聯(lián)是一家專注于成都做網(wǎng)站、成都網(wǎng)站設(shè)計與策劃設(shè)計,畢節(jié)網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10余年,網(wǎng)設(shè)計領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:畢節(jié)等地區(qū)。畢節(jié)做網(wǎng)站價格咨詢:13518219792
Document 把要上傳的文件拖動到這里
2. 檢測拖動事件
首先讓頁面支持文件拖拽,在 Vue 的 mounted() 函數(shù)中添加代碼:
mounted: function () { var dropbox = document.querySelector('.dropbox'); dropbox.addEventListener('dragenter', this.onDrag, false); dropbox.addEventListener('dragover', this.onDrag, false); dropbox.addEventListener('drop', this.onDrop, false); }
當(dāng)把文件拖動到瀏覽器的拖動區(qū)域時,會觸發(fā)三種事件:
實現(xiàn)拖動上傳,我們只需要關(guān)心 drop 事件。不過另外兩個事件也需要監(jiān)聽,目的是阻止瀏覽器默認(rèn)行為。如果不阻止,那么把文件拖到瀏覽器時,瀏覽器就會自動下載這個文件(默認(rèn)行為),drop 事件觸發(fā)不出來。
事件的監(jiān)聽函數(shù)添加在 Vue 的 methods 對象中:
methods: { uploadFile: function (file) { console.log(file); }, onDrag: function (e) { e.stopPropagation(); e.preventDefault(); }, onDrop: function (e) { e.stopPropagation(); e.preventDefault(); var dt = e.dataTransfer; for (var i = 0; i !== dt.files.length; i++) { this.uploadFile(dt.files[i]); } } },
onDrop() 函數(shù)中,通過 e.dataTransfer.files 可以拿到用戶拖動到瀏覽器的文件的基本信息,uploadFile() 函數(shù)現(xiàn)在只這些信息打印了出來,可以了解到,拖動到瀏覽器的每個文件都是一個 File 對象:
3. 處理拖動事件
現(xiàn)在,我們要給 uploadFile() 函數(shù)增加功能,實現(xiàn)拖動文件時,拖動區(qū)出現(xiàn)文件名和一個上傳進(jìn)度條。
首先在 Vue 的 data 對象中定義 files 屬性,用來保存所有拖動到瀏覽器中文件的名稱。然后在uploadFile() 函數(shù)每當(dāng)被調(diào)用時,把文件名和上傳進(jìn)度保存到 files 中:
data: { files: [] }, methods: { uploadFile: function (file) { var item = { name: file.name, uploadPercentage: 67 }; this.files.push(item); }, }
上傳進(jìn)度的功能在后面再介紹,先寫一個固定值。
相應(yīng)地,在HTML代碼中,用 v-for 關(guān)鍵字顯示 files 的每一項:
把要上傳的文件拖動到這里
{{ file.name }}
而且,“把要上傳的文件拖動到這里” 的提示只在拖動區(qū)沒有文件的時候才顯示:
把要上傳的文件拖動到這里
這樣,拖動效果就有了:
4. 文件上傳
接下來實現(xiàn)真正的文件上傳,繼續(xù)往 uploadFile() 函數(shù)添加代碼:
uploadFile: function (file) { var item = { name: file.name, uploadPercentage: 67 }; this.files.push(item); var fd = new FormData(); fd.append('myFile', file); var xhr = new XMLHttpRequest(); xhr.open('POST', 'upload.php', true); xhr.send(fd); },
這里用到了 FormData,把要上傳的文件附在了 FormData 上,并通過AJAX方式發(fā)送給PHP端。PHP端代碼:
if (isset($_FILES['myFile'])) { move_uploaded_file($_FILES['myFile']['tmp_name'], 'uploads/' . $_FILES['myFile']['name']); echo 'OK'; } else { echo 'No file specified'; }
現(xiàn)在刷新下頁面,把電腦上的兩個文件拖到瀏覽器中,PHP端會接收并保存文件到 uploads 目錄:
提示:如果拖放時遇到PHP返回了No file specified,或者 $_FILES 為 NULL 的情況時,有可能是PHP限制了POST請求最大字節(jié),或者限制了上傳文件的體積。這時候需要調(diào)整下php.ini中的這兩個配置:
post_max_size = 20M // POST請求的最大字節(jié)數(shù) upload_max_filesize = 20M // 上傳文件的最大體積
進(jìn)度條的展示
基本的上傳功能完成了,最后我們來完成進(jìn)度條。每當(dāng)AJAX請求發(fā)送了一段時間的數(shù)據(jù)時,都會生成一個 progress 事件,我們可以監(jiān)聽 progress 事件來知道當(dāng)前的上傳進(jìn)度:
uploadFile: function (file) { ... xhr.upload.addEventListener('progress', function (e) { item.uploadPercentage = Math.round((e.loaded * 100) / e.total); }, false); xhr.send(fd); },
e.loaded 代表當(dāng)前AJAX發(fā)送了多少字節(jié),e.total 代表AJAX總共要發(fā)送多少字節(jié)。通過這兩個屬性可以計算上傳進(jìn)度的百分比。
這樣,一個帶進(jìn)度條的文件拖動上傳功能就完成了。
附:完整代碼
Document 把要上傳的文件拖動到這里
{{ file.name }}
總結(jié)
以上所述是小編給大家介紹的Vue實現(xiàn)帶進(jìn)度條的文件拖動上傳功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!