真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Vue實現(xiàn)帶進(jìn)度條的文件拖動上傳功能

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


把要上傳的文件拖動到這里

Vue實現(xiàn)帶進(jìn)度條的文件拖動上傳功能

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ā)三種事件:

  1. 文件第一次進(jìn)入拖動區(qū)時,觸發(fā) dragenter 事件
  2. 文件在拖動區(qū)來回拖拽時,不斷觸發(fā) dragover 事件
  3. 文件已經(jīng)在拖動區(qū),并松開鼠標(biāo)時,觸發(fā) drop 事件

實現(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 對象:

Vue實現(xiàn)帶進(jìn)度條的文件拖動上傳功能

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ū)沒有文件的時候才顯示:

把要上傳的文件拖動到這里

這樣,拖動效果就有了:

Vue實現(xiàn)帶進(jìn)度條的文件拖動上傳功能

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 目錄:

Vue實現(xiàn)帶進(jìn)度條的文件拖動上傳功能

提示:如果拖放時遇到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)站的支持!


當(dāng)前文章:Vue實現(xiàn)帶進(jìn)度條的文件拖動上傳功能
網(wǎng)頁鏈接:http://weahome.cn/article/pcepid.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部