老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

如何在微信小程序中使用Promise

這篇文章給大家介紹如何在微信小程序中使用Promise,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

創新互聯公司是一家專業從事成都網站設計、成都網站制作、網頁設計的品牌網絡公司。如今是成都地區具影響力的網站設計公司,作為專業的成都網站建設公司,創新互聯公司依托強大的技術實力、以及多年的網站運營經驗,為您提供專業的成都網站建設、營銷型網站建設及網站設計開發服務!

Promise 是異步編程的一種解決方案,比傳統的解決方案——回調函數和事件——更合理和更強大。它由社區最早提出和實現,ES6 將其寫進了語言標準,統一了用法,原生提供了Promise對象。

所謂Promise,簡單說就是一個容器,里面保存著某個未來才會結束的事件(通常是一個異步操作)的結果。從語法上說,Promise 是一個對象,從它可以獲取異步操作的消息。Promise 提供統一的 API,各種異步操作都可以用同樣的方法進行處理。

了解什么是 Promise 對象

比如下面這種

// 模擬獲取code,然后將code傳給后臺,成功后獲取userinfo,再將userinfo傳給后臺
// 登錄
wx.login({
  success: res => {
    let code = res.code
    // 請求
    imitationPost({
      url: '/test/loginWithCode',
      data: {
        code
      },
      success: data => {
        // 獲取userInfo
        wx.getUserInfo({
          success: res => {
            let userInfo = res.userInfo
            // 請求
            imitationPost({
              url: '/test/saveUserInfo',
              data: {
                userInfo
              },
              success: data => {
                console.log(data)
              },
              fail: res => {
                console.log(res)
              }
            })
          },
          fail: res => {
            console.log(res)
          }
        })
      },
      fail: res => {
        console.log(res)
      }
    })
  },
  fail: res => {
    console.log(res)
  }
})

下面分析如何用Promise來進行簡化代碼

因為微信小程序異步api都是success和fail的形式,所有有人封裝了這樣一個方法:

promisify.js

module.exports = (api) => {
  return (options, ...params) => {
    return new Promise((resolve, reject) => {
      api(Object.assign({}, options, { success: resolve, fail: reject }), ...params);
    });
  }
}

先看最簡單的:

// 獲取系統信息
wx.getSystemInfo({
  success: res => {
    // success
    console.log(res)
  },
  fail: res => {

  }
})

使用上面的promisify.js簡化后:

const promisify = require('./promisify')
const getSystemInfo = promisify(wx.getSystemInfo)

getSystemInfo().then(res=>{
  // success
  console.log(res)
}).catch(res=>{

})

如何在微信小程序中使用Promise

getSystemInfo

可以看到簡化后的回調里少了一個縮進,并且回調函數從9行減少到了6行。

回調金字塔的簡化效果

那么再來看看最開始的那個回調金字塔

const promisify = require('./promisify')
const login = promisify(wx.login)
const getSystemInfo = promisify(wx.getSystemInfo)

// 登錄
login().then(res => {
  let code = res.code
  // 請求
  pImitationPost({
    url: '/test/loginWithCode',
    data: {
      code
    },
  }).then(data => {
    // 獲取userInfo
    getUserInfo().then(res => {
      let userInfo = res.userInfo
      // 請求
      pImitationPost({
        url: '/test/saveUserInfo',
        data: {
          userInfo
        },
      }).then(data => {
        console.log(data)
      }).catch(res => {
        console.log(res)
      })
    }).catch(res => {
      console.log(res)
    })
  }).catch(res => {
    console.log(res)
  })
}).catch(res => {
  console.log(res)
})

如何在微信小程序中使用Promise

關于如何在微信小程序中使用Promise就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。


本文名稱:如何在微信小程序中使用Promise
網站網址:http://www.xueling.net.cn/article/jseoco.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 国产成人美女AV | 国产欧美久久久精品二区仙踪林 | 欧美最猛性bbbbxxxx | 亚洲欧美日本国产专区一区 | 色小妹av| 亚洲ww77777影视 | 遮天在哪个软件可以免费阅读 | 大地资源网高清视频怎么在线 | 一级免费在线视频 | 日本在线看片 | 人人添人人澡人人澡人人人人 | 色综合久久久无码中文字幕 | 午夜理论2019理论无码 | 怡红院A∨人人爰人人爽 | 亚洲综合成人影院 | 2024丁香五月天之婷婷综合缴情 | 水蜜桃yy8848私人视院 | 中文字幕けのぁ一般男女 | 日韩9999| 国产精品人妻99一区二区三区 | 老师和学生69xxxx18 | 女人与禽姓交视免费看 | 亚洲精品国产自在现线看 | av中文一区二区三区 | 国产精品视频500部 大地影视资源中文 | 古代春交性姿势K8 | 五月天综合婷婷欧美专区 | 欧美草草 | 91插插插插插插 | 青青草国产免费无码 | 毛片免费观看网址 | 亚洲黄色免费网站 | 国产精品久久久久久久久久10秀 | 99中文字幕 | 久久综合五月丁香六月丁香 | 一个人看的www免费视频在线观看 | 日本欧美大码A在线观看 | 午夜影院在线播放 | 视频一级片 | 色在线免费观看 | 永久免费无码网站在线观看个 |