欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序promsie.all和promise順序執(zhí)行

 更新時間:2017年10月27日 10:06:14   作者:shellteo  
這篇文章主要介紹了微信小程序promsie.all和promise順序執(zhí)行的相關資料,希望通過本文能幫助到大家,需要的朋友可以參考下

微信小程序promsie.all和promise順序執(zhí)行

一、前言

最近在做小程序的開發(fā),碰到的一個需求就是表單提交,提交的表單中包含有圖片,微信這邊的做法是先上傳圖片,后臺把圖片名稱和地址返回給你,然后你把圖片信息插入到表單的相應位置再提交表單,這里就涉及到如何上傳完圖片的請求再上傳表單,而且微信小程序里面如果圖片是多個的話,也只能一張張上傳。簡單來說就是上傳完圖片(多個請求),拿到返回值,再上傳表單,該如何做?

二、Promise.all和Promise.race

先來介紹Promise.all和Promise.race方法的不同點Promise.all(iterable) 方法指當所有在可迭代參數(shù)中的 promises 已完成,或者第一個傳遞的 promise(指 reject)失敗時,返回 promise。iterable為可迭代對象,但是一般為數(shù)組。返回值也是一個Promise對象。

需要明確的幾點,Promise.all是并發(fā)執(zhí)行的同時運行多個Promise對象,而且返回的Promise對象的參數(shù)是一個數(shù)組,數(shù)組中的各項也是可迭代對象執(zhí)行的順序返回。

Promise.race(iterable) 方法返回一個新的 promise,參數(shù)iterable中只要有一個promise對象”完成(resolve)”或”失?。╮eject)”,新的promise就會立刻”完成(resolve)”或者”失?。╮eject)”,并獲得之前那個promise對象的返回值或者錯誤原因。所以只要iterable中有一個完成或者失敗就立即返回一個promise對象。根據(jù)race這個單詞為賽跑也能得出,最先到達的立即返回一個promise對象。

根據(jù)上面的定義,我們采用的Promise.all方法來完成我們的需求。

//存儲promise對象的數(shù)組
let promiseArr = [];
//圖片地址數(shù)組
let imageList = [];
//將圖片地址的上傳的promise對象加入到promiseArr
for (let i = 0; i < imageList.length; i++) {
  let promise = new Promise((resolve, reject) => {
    //微信圖片上傳
    wx.uploadFile({
      url: 'https://xxx.xxx.xxx/api/uploadImage',
      filePath: imageList[i],
      name: 'file',
      success: function(res) {
        //可以對res進行處理,然后resolve返回
        resolve(res);
      },
      fail: function (error) {
        reject(error);
      },
      complete: function (res) {
      },
    })
  });
  promiseArr.push(promise)
}
//Promise.all處理promiseArr數(shù)組中的每一個promise對象
Promise.all(promiseArr).then((result) => {
  //對返回的result數(shù)組進行處理
})

三、微信小程序的問題

在做微信小程序的圖片上傳功能,這邊只能先上傳圖片,然后將圖片名和地址以response返回。

這里面我們就是用了promise.all方法但是有一個問題就是,promise.all是并發(fā)執(zhí)行的,但是微信小程序一次只能并發(fā)10個請求。

對于圖片上傳,可能需要一次上傳超過10張圖片,也就是一次并發(fā)超過10個請求,這樣的話微信就會報錯

“WAService.js:4 uploadFile:fail createUploadTask:fail exceed max upload connection count 10”。

四、順序Promise執(zhí)行處理

因為Promise.all是同時運行多個promsie對象,所以對于這種并發(fā)的數(shù)量,小程序是有限制的,一次只能并發(fā)10個,所以如果想突破這種限制,可以進行順序執(zhí)行每個Promise。

代碼如下:

//順序處理函數(shù)
function sequenceTasks(tasks) {
  //記錄返回值
  function recordValue(results, value) {
    results.push(value);
    return results;
  }
  let pushValue = recordValue.bind(null, []);
  let promise = Promise.resolve();
  // 處理tasks數(shù)組中的每個函數(shù)對象
  for (let i = 0; i < tasks.length; i++) {
    let task = tasks[i];
    promise = promise.then(task).then(pushValue);
  }
  return promise;
}

//函數(shù)數(shù)組,每個函數(shù)的返回值是一個promise對象
let promiseFuncArr = [];
//圖片地址數(shù)組
let imageList = [];
//將圖片地址的上傳的函數(shù)加入到promiseFuncArr數(shù)組中
for (let i = 0; i < imageList.length; i++) {
  let promiseTemp = function(){
    return new Promise((resolve, reject) => {
      //微信圖片上傳
      wx.uploadFile({
        url: 'https://xxx.xxx.xxx/api/uploadImage',
        filePath: imageList[i],
        name: 'file',
        success: function(res) {
          //可以對res進行處理,然后resolve返回
          resolve(res);
        },
        fail: function (error) {
          reject(error);
        },
        complete: function (res) {
        },
      })
    });
  };
  promiseFuncArr.push(promiseTemp)
}

sequenceTasks(promiseFuncArr).then((result) => {
  //對返回的result數(shù)組進行處理
});

1.這里解釋一下sequenceTasks函數(shù)的作用

首先recordValue函數(shù)傳入兩個值,一個是results是返回的數(shù)組,另一個是value,value是傳入的值,results.push(value);將每一個值push到results數(shù)組,然后再返回results數(shù)組。

let pushValue = recordValue.bind(null, []);

pushValue也是一個函數(shù)對象,將recordValue bind到一個[ ]數(shù)組中,第一個參數(shù)傳null代表,不改變函數(shù)this的指向,所以pushValue得到就是一個function (value)的函數(shù),參數(shù)傳入value。

promise = promise.then(task).then(pushValue);

task是函數(shù),函數(shù)返回promise對象,在我們這里就是上傳圖片函數(shù),每一張圖片上傳都創(chuàng)建一個函數(shù),then(pushValue),pushValue是function (value)的函數(shù),value代表的就是圖片上傳之后的返回值,pushValue將返回值push到result數(shù)組中,依次執(zhí)行,依次加入到result數(shù)組中,最后返回。就可以得到一個對象數(shù)組,數(shù)組中就是依次執(zhí)行返回的結果。

2. sequenceTasks也里面的for循環(huán),也可以寫成如下的reduce方式:

function sequenceTasks(tasks) {
  //記錄返回值
  function recordValue(results, value) {
    results.push(value);
    return results;
  }
  let pushValue = recordValue.bind(null, []);
  return tasks.reduce(function (promise, task) {
    return promise.then(task).then(pushValue);
  }, Promise.resolve());
}

如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關文章

  • 微信小程序 template模板詳解及實例代碼

    微信小程序 template模板詳解及實例代碼

    這篇文章主要介紹了微信小程序 template模板詳解及實例代碼的相關資料,需要的朋友可以參考下
    2017-03-03
  • JS前端輕量fabric.js系列物體基類

    JS前端輕量fabric.js系列物體基類

    這篇文章主要為大家介紹了實現(xiàn)JS前端輕量fabric.js系列物體基類示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 微信小程序 MD5加密登錄密碼詳解及實例代碼

    微信小程序 MD5加密登錄密碼詳解及實例代碼

    這篇文章主要介紹了微信小程序 MD5加密登錄密碼詳解及實例代碼的相關資料,這里附有實例代碼,需要的朋友可以參考下
    2017-01-01
  • 微信小程序 使用picker封裝省市區(qū)三級聯(lián)動實例代碼

    微信小程序 使用picker封裝省市區(qū)三級聯(lián)動實例代碼

    這篇文章主要介紹了微信小程序 使用picker封裝省市區(qū)三級聯(lián)動實例代碼的相關資料,需要的朋友可以參考下
    2016-10-10
  • 一文解析Express框架view對象使用

    一文解析Express框架view對象使用

    這篇文章主要介紹了Express框架view對象使用解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • async-await消滅異步回調實例詳解

    async-await消滅異步回調實例詳解

    這篇文章主要為大家介紹了async-await消滅異步回調實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • js展示百度地圖及添加標注實現(xiàn)

    js展示百度地圖及添加標注實現(xiàn)

    這篇文章主要為大家介紹了js展示百度地圖及添加標注實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • js 實現(xiàn)文件上傳樣式詳情

    js 實現(xiàn)文件上傳樣式詳情

    這篇文章主要介紹了js 實現(xiàn)文件上傳樣式,下面文章舉例說明js 是如何實現(xiàn)文件上傳樣式的,附有代碼詳細解說,需要的朋友可以參考一下,希望對你有所幫助
    2021-10-10
  • 微信小程序 實現(xiàn)動態(tài)顯示和隱藏某個控件

    微信小程序 實現(xiàn)動態(tài)顯示和隱藏某個控件

    這篇文章主要介紹了微信小程序 實現(xiàn)動態(tài)顯示和隱藏某個控件的相關資料,需要的朋友可以參考下
    2017-04-04
  • JavaScript的單線程和異步詳細

    JavaScript的單線程和異步詳細

    這篇文章要給大家分享的是JavaScript的單線程和異步,其實單線程和異步確實不能同時成為一個語言的特性,js選擇了成為單線程的語言,所以它本身不可能是異步的,但js宿主環(huán)境是多線程,宿主環(huán)境通過某種方式使js具備了異步屬性,下面就來具體介紹,需要的朋友可以參考一下
    2021-10-10

最新評論