詳解vue 圖片上傳功能

這篇文章主要介紹了vue 圖片上傳功能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨着小編來一起學習學習吧

這次做了vue頁面的圖片上傳功能,不帶裁剪功能的!

首先是html代碼,在input框上添加change事件,如下:

<ul class="clearfix">
        <li v-if="imgs.length>0" v-for='(item ,index ) in imgs'>
          <img :src="item">
        </li>
        <li style="position:relative" v-if="imgs.length>=6 ? false : true">
          <img src="../../assets/img/addimg.png"><input class="upload" @change='add_img' type="file">
        </li>
</ul>

我這裏做了圖片數量的限制,最多6張。

然後是data數據,如下:

data () {
  return {
    imgs: [],
    imgData: {
      accept: 'image/gif, image/jpeg, image/png, image/jpg',
    }
  }
 }

imgs數組是放圖片路徑的,頁面顯示圖片就是循環這個數組,imgData是判斷圖片類型的。

接下來是最重要的methods裏面的方法,具體如下:

add_img(event){ 
      let reader =new FileReader();
      let img1=event.target.files[0];
      let type=img1.type;//文件的類型,判斷是否是圖片
      let size=img1.size;//文件的大小,判斷圖片的大小
      if(this.imgData.accept.indexOf(type) == -1){
        alert('請選擇我們支持的圖片格式!');
        return false;
      }
      if(size>3145728){
        alert('請選擇3M以內的圖片!');
        return false;
      }
      var uri = ''
      let form = new FormData(); 
      form.append('file',img1,img1.name);
      this.$http.post('/file/upload',form,{
        headers:{'Content-Type':'multipart/form-data'}
      }).then(response => {
        console.log(response.data)
        uri = response.data.url
        reader.readAsDataURL(img1);
        var that=this;
        reader.onloadend=function(){
          that.imgs.push(uri);
        }
      }).catch(error => {
        alert('上傳圖片出錯!');
      })  
},

首先是獲取你選擇的圖片,判斷圖片的類型和大小,然後以form表單的形式提交到後臺,後臺會返回給你這個圖片的線上路徑,你把後臺返回的圖片路徑push到圖片數組裏面就可以了。

一般情況下還有刪除圖片的方法,就是把圖片數組裏的那個路徑刪除掉,把數據提交到後臺,告訴後臺刪除了哪張圖片就可以了。

以上所述是小編給大家介紹的vue 圖片上傳功能詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對神馬文庫網站的支持!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章