vue中使用axios post上傳頭像/圖片並實時顯示到頁面


在前端開發中,為了更好的用戶體驗,在頭像上傳時會先將圖片顯示到頁面然后點擊保存按鈕 完成圖片的上傳成功 代碼部分有參考他人的寫法。

html代碼:

  1.  
    <div id="myPhoto" v-show="personalPhoto">
  2.  
    <div class="viewPhoto">
  3.  
    <img src="" alt="" id="portrait"style="width: 300px;height: 300px" />
  4.  
    </div>
  5.  
    <div class="listBox">
  6.  
    <dl>
  7.  
    <dt>請上傳圖片</dt>
  8.  
    <dd>
  9.  
    <input type="file"id="saveImage" name="myphoto" >
  10.  
    </dd>
  11.  
    </dl>
  12.  
    </div>
  13.  
    <div class="save">
  14.  
    <input type="button" value="保存圖片" @click="imageSubmit">
  15.  
    </div>
  16.  
    </div>

js代碼:

  1.  
    //實時顯示該圖片在頁面
  2.  
     great(){
  3.  
    document.getElementById('saveImage').onchange = function () {
  4.  
    var imgFile = this.files[0];
  5.  
    var fr = new FileReader();
  6.  
    fr.onload = function () {
  7.  
    document.getElementById('portrait').src = fr.result;
  8.  
    };
  9.  
    fr.readAsDataURL(imgFile);
  10.  
    }
  11.  
    },

js代碼部分說明:因為是在vue的methods方法中申明的函數,所以還需要在mounted 方法中使用this.great()掛載該方法。

圖片上傳部分的js代碼:

  1.  
    imageSubmit(){
  2.  
    let x = document.getElementById('saveImage').files[0];
  3.  
    console.log(x);
  4.  
    let params = new FormData() ; //創建一個form對象
  5.  
    params.append('file',x,x.name); //append 向form表單添加數據
  6.  
    //添加請求頭 通過form添加的圖片和文件的格式必須是multipart/form-data
  7.  
    let config = {
  8.  
    headers:{'Content-Type':'multipart/form-data'}
  9.  
    };
  10.  
    this.$axios.post("/user/image",params,config)
  11.  
    .then(function(res){
  12.  
    console.log(res);
  13.  
    this.imageSave = res.data.image;
  14.  
    sessionStorage.setItem('headImg',this.imageSave); //將圖片保存,並能夠在其他地方加載顯示
  15.  
    router.go(0); //刷新頁面,頭像改變
  16.  
    }.bind(this))
  17.  
    .catch(function (error) {
  18.  
    console.log(error);
  19.  
    })
  20.  
    }
  21.  
    },

最終效果圖:

注:在后來的開發過程中發現,上傳圖片在上傳服務器前在頁面加載可以使用

var windowURL = window.URL || window.webkitURL;

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM