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

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

vue中怎么實現(xiàn)一個上傳圖片組件

本篇文章給大家分享的是有關vue中怎么實現(xiàn)一個上傳圖片組件,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

“只有客戶發(fā)展了,才有我們的生存與發(fā)展!”這是成都創(chuàng)新互聯(lián)的服務宗旨!把網站當作互聯(lián)網產品,產品思維更注重全局思維、需求分析和迭代思維,在網站建設中就是為了建設一個不僅審美在線,而且實用性極高的網站。創(chuàng)新互聯(lián)對做網站、成都網站設計、網站制作、網站開發(fā)、網頁設計、網站優(yōu)化、網絡推廣、探索永無止境。

1.首先得有一個[type=file]文件標簽并且隱藏,changge事件來獲取圖片:

2.觸發(fā)隱藏的文件標簽:(通過原生的click來觸發(fā))

document.getElementById('upload_file').click()

3.獲取file文件里面的值方法:fileChange($event)

fileChange(el){ 
  if (!el.target.files[0].size) return;//判斷是否有文件數(shù)量 
  this.fileList(el.target.files);//獲取files文件組傳入處理 
  el.target.value = ''//清空val值,以便可以重復添加一張圖片 
 }

4.處理files文件組

獲取傳入單個圖片文件

fileList(files){ 
   for (let i = 0; i < files.length; i++) { 
    this.fileAdd(files[i]); 
   } 
  }

處理獲取到的圖片文件,統(tǒng)計文件大小,轉圖片為base64以供顯示

fileAdd(file){ 
   this.size = this.size + file.size;//總大小 
   let reader = new FileReader(); 
   reader.vue = this; 
   reader.readAsDataURL(file); 
   reader.onload = function () { 
    file.src = this.result; 
    this.vue.imgList.push({ 
     file 
    }); 
   } 
  },

5.文件大小換算

bytesToSize(bytes){ 
  if (bytes === 0) return '0 B'; 
  let k = 1000, // or 1024 
   sizes = ['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'], 
   i = Math.floor(Math.log(bytes) / Math.log(k)); 
  return (bytes / Math.pow(k, i)).toPrecision(3) + ' ' + sizes[i]; 
 },

6.拖拽上傳

 
   或者將文件拖到此處 
dragenter(el){ 
  el.stopPropagation(); 
  el.preventDefault(); 
 }, 
 dragover(el){ 
  el.stopPropagation(); 
  el.preventDefault(); 
 }, 
 drop(el){ 
  el.stopPropagation(); 
  el.preventDefault(); 
  this.fileList(el.dataTransfer.files); 
 }

最終效果如下:

vue中怎么實現(xiàn)一個上傳圖片組件

以上就是vue中怎么實現(xiàn)一個上傳圖片組件,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


網站欄目:vue中怎么實現(xiàn)一個上傳圖片組件
文章URL:http://weahome.cn/article/ihppec.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部