溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

小程序開發(fā)中如何實(shí)現(xiàn)一個(gè)圖片上傳功能

發(fā)布時(shí)間:2020-11-19 15:24:33 來源:億速云 閱讀:283 作者:Leah 欄目:開發(fā)技術(shù)

小程序開發(fā)中如何實(shí)現(xiàn)一個(gè)圖片上傳功能?很多新手對此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

具體內(nèi)容如下

Page({

 /**
  * 頁面的初始數(shù)據(jù)
  */
 data: {
  pics: [],
  count: 9, //上傳圖片最大數(shù)量
  // showImgUrl: "", //路徑拼接,一般上傳返回的都是文件名,
  uploadImgUrl: 'https://xxx/UploadHandler.ashx', //圖片的上傳的路徑
  detailPics: [], //上傳的結(jié)果圖片集合
 },
 selectimages() {
  var that = this;
  var detailPics = that.data.detailPics;
  if (detailPics.length >= that.data.count) {
   wx.showToast({
    title: '最多選擇' + that.data.count + '張!',
   })
   return;
  }
  wx.chooseImage({
   count: that.data.count, // 最多可以選擇的圖片張數(shù),默認(rèn)9
   sizeType: ['original', 'compressed'], // original 原圖,compressed 壓縮圖,默認(rèn)二者都有
   sourceType: ['album', 'camera'], // album 從相冊選圖,camera 使用相機(jī),默認(rèn)二者都有
   success: function(res) {
    var imgs = res.tempFilePaths;
    for (var i = 0; i < imgs.length; i++) {
     that.data.pics.push(imgs[i])
    }
    that.setData({
     pics: that.data.pics
    })
    console.log(that.data.pics)
     that.uploadimg({
     url: that.data.uploadImgUrl, //這里是你圖片上傳的接口
     path: that.data.pics, //這里是選取的圖片的地址數(shù)組
    });
   },
  })
 },
 //多張圖片上傳
 uploadimg: function(data) {
  wx.showLoading({
   title: '上傳圖片中...',
   mask: true,
  })
  var that = this,
   i = data.i &#63; data.i : 0,
   success = data.success &#63; data.success : 0,
   fail = data.fail &#63; data.fail : 0;
  wx.uploadFile({
   url: data.url,
   filePath: data.path[i],
   name: 'fileData',
   formData: null,
   success: (resp) => {
    wx.hideLoading();
    success++;
    var str = resp.data //返回的結(jié)果,可能不同項(xiàng)目結(jié)果不一樣
    var pic = JSON.parse(str);
    var pic_name = pic.url;
    var detailPics = that.data.detailPics;
    detailPics.push(pic_name)
    that.setData({
     detailPics: detailPics
    })
   },
   fail: (res) => {
    fail++;
    console.log('fail:' + i + "fail:" + fail);
   },
   complete: () => {
    i++;
    if (i == data.path.length) { //當(dāng)圖片傳完時(shí),停止調(diào)用   
     that.send()
     console.log('執(zhí)行完畢');
     console.log('成功:' + success + " 失?。?quot; + fail);
     var myEventDetail = {
      picsList: that.data.detailPics
     } // detail對象,提供給事件監(jiān)聽函數(shù)
     var myEventOption = {} // 觸發(fā)事件的選項(xiàng)
     that.triggerEvent('myevent', myEventDetail, myEventOption) //結(jié)果返回調(diào)用的頁面
    } else { //若圖片還沒有傳完,則繼續(xù)調(diào)用函數(shù)
     data.i = i;
     data.success = success;
     data.fail = fail;
     that.uploadimg(data); //遞歸,回調(diào)自己
    }
   }
  });
 },
})

效果圖:

小程序開發(fā)中如何實(shí)現(xiàn)一個(gè)圖片上傳功能

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI