亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 課堂 > 小程序 > 正文

詳解在微信小程序的JS腳本中使用Promise來優化函數處理

2020-03-21 16:00:59
字體:
來源:轉載
供稿:網友

在我們傳統的Javascript開發函數編寫中,我們習慣了回調函數的處理,不過隨著回調函數的增多,以及異步處理的復雜性等原因,代碼越來越難讀,因此誕生了使用Promise來優化JS函數處理的需求,引入Promise確實能夠很好的解決異步回調函數的可讀性等問題,同時也使得我們調用的時候代碼簡潔一些,本文介紹如何在小程序的JS代碼里面使用Promise來封裝一些函數的做法。

1、小程序傳統的回調處理

例如我們生成一個小程序,里面的app.js里面就自動帶有一個getUserInfo的函數,這個是使用傳統模式的回調函數。

//app.jsApp({ onLaunch: function () { //調用API從本地緩存中獲取數據 var logs = wx.getStorageSync('logs') || [] logs.unshift(Date.now()) wx.setStorageSync('logs', logs) },  getUserInfo:function(cb){ var that = this if(this.globalData.userInfo){  typeof cb == "function" && cb(this.globalData.userInfo) }else{  //調用登錄接口  wx.login({  success: function () {   wx.getUserInfo({   success: function (res) {    that.globalData.userInfo = res.userInfo    typeof cb == "function" && cb(that.globalData.userInfo)   }   })  }  }) } }, globalData:{ userInfo: null, openid: null }})

這種是通過 傳入一個cb的回調函數進行處理,使用的時候為了安全性,還需要進一步判斷其類型是否為函數:typeof cb == "function",這種處理還是相對比較易懂。

但是,如果我們一段代碼中,異步操作太多,又要保證這些異步操作是有順序的執行,那我們的代碼就看起來非常糟糕,就像這樣的極端情況:

asyncFunc1(function(){ //... asyncFunc2(function(){ //... asyncFunc3(function(){  //...  asyncFunc4(function(){  //...  asyncFunc5(function(){   //...  });  }); }); });});

如果我們改用Promise來處理,那么進行一層簡單的包裝即可。

function asyncFunc1(){ return new Promise(function (resolve, reject) { //... })}

2、Promise的使用介紹

Promise的使用相對比較簡單,我們入門可以參考下相關介紹:阮一峰 promise入門,如果我們在JS函數里面引入它的話,那么需要包含對應的javascript組件

我們可以在Github上下載對應的組件JS,引入小程序項目即可:es6-promise

我們為了方便,在項目中創建一個輔助類utils.js,然后在其中引入Promise的腳本,如下所示。

const Promise = require('./Promise')

然后在APP.js里面,我們修改原來的getUserInfo函數如下 

//app.jsconst utils = require('./utils/util.js')App({ onLaunch: function() {  //調用API從本地緩存中獲取數據  var logs = wx.getStorageSync('logs') || []  logs.unshift(Date.now())  wx.setStorageSync('logs', logs) }, getUserInfo() {  return new utils.Promise((resolve, reject) => {   if (this.globalData.userInfo) {    resolve(this.globalData.userInfo)   }   return utils.getUserInfo().then(res => {    resolve(this.globalData.userInfo = res.userInfo)   })  }) }, //獲取系統信息 getSystemInfo() {  return new utils.Promise((resolve, reject) => {   var that = this   if (that.globalData.systemInfo) {    resolve(that.globalData.systemInfo)   } else {    wx.getSystemInfo({     success: function(res) {      resolve(that.globalData.systemInfo = res);     }    })   }  }) }, //全局對象 globalData: {  userInfo: null,  systemInfo: null }, utils})

我們看到,所有原先的函數,我們如果需要引入Promise處理的話,增加一層的函數體即可。

return new utils.Promise((resolve, reject) => {    // 原來的函數體代碼 });

這樣我們調用的時候,使用then函數進行處理即可,類似下面的代碼。

getUserInfo().then(user => this.setData({userInfo:user})).catch(console.log);

引入這個Promise后,我們為了進一步實現代碼的重用,可以把一些常見的函數放到utils.js來,這樣可以實現代碼的重用。

//用戶登錄function login(){ return new Promise((resolve,reject) => wx.login({ success:resolve, fail:reject }))}//獲取用戶信息function getUserInfo(){ return login().then(res => new Promise((resolve,reject) =>  wx.getUserInfo({  success:resolve,  fail:reject }) ))}
function requstGet(url,data){ return requst(url,'GET',data)}function requstPost(url,data){ return requst(url,'POST',data)}//封裝Request請求方法function requst(url,method,data = {}){ wx.showNavigationBarLoading() data.method = method return new Promise((resove,reject) => { wx.request({  url: url,  data: data,  header: {},  method: method.toUpperCase(), // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT  success: function(res){  wx.hideNavigationBarLoading()  resove(res.data)  },  fail: function(msg) {  console.log('reqest error',msg)  wx.hideNavigationBarLoading()  reject('fail')  } }) })}

然后發布對應的接口,以供其他模塊使用即可。 

//發布的接口module.exports = { Promise,makeArray,getUserInfo, get:requstGet,post:requstPost,requst,decodeHtml, formatTime,getDateDiff}

封裝好這些公用方法后,我們在頁面里面進行調用即可,調用的代碼如下所示(演示代碼從地址里面獲取數據,并綁定到界面上)

  //使用Comprise的封裝函數展現  var url ='http://localhost:27206/api/Framework/Information/FindByCode';  var companyurl = "http://www.iqidi.com";  var json = {code: 'company'};  app.utils.get(url, json).then(function(res) {   var data = { url: companyurl, image: res.Picture, content: res.Content };  that.setData({   item : data  });  WxParse.wxParse('content', 'html', data.content, that, 25);  }); 

而如果我們使用原來的函數,那么實現代碼如下所示。

  // 使用標準的wx.request函數實現展現  var url ='http://localhost:27206/api/Framework/Information/FindByCode';  var companyurl = "http://www.iqidi.com";  var json = {code: 'company'};  wx.request({   url: url,   data: json,   success: function(res) {   console.log(res);   var data = { url: companyurl, image: res.data.Picture, content: res.data.Content };   that.setData({    item : data   });   WxParse.wxParse('content', 'html', data.content, that, 25);   }  }) 

如果對于復雜流程的函數處理,使用Promise來處理,會顯得更加簡潔易讀。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久久久久久久国产| 久久久久久久电影一区| 欧美成人剧情片在线观看| 欧美精品在线视频观看| 欧美野外猛男的大粗鳮| 亚洲精品白浆高清久久久久久| 国产精品免费福利| 最近2019中文字幕一页二页| 青青草99啪国产免费| 亚洲伊人久久综合| 日韩电影第一页| 中文字幕精品国产| 6080yy精品一区二区三区| 一区二区三区视频免费在线观看| 日本欧美在线视频| 欧美激情一级二级| 亚洲a在线播放| 精品国产欧美成人夜夜嗨| 欧美高清videos高潮hd| 欧美最猛黑人xxxx黑人猛叫黄| 久久精品在线视频| 中文字幕一区二区三区电影| 超碰97人人做人人爱少妇| 欧美激情精品久久久久久免费印度| 亚洲欧美综合v| 欧美日韩国产丝袜美女| 成人黄色在线观看| 一本一本久久a久久精品综合小说| 日韩美女视频免费看| 91精品久久久久久久久久入口| 91精品国产综合久久香蕉的用户体验| 成人午夜两性视频| 欧美午夜宅男影院在线观看| 国产99视频在线观看| 久久影视免费观看| www.日韩视频| 国产一区玩具在线观看| 伊人男人综合视频网| 高清日韩电视剧大全免费播放在线观看| 久久av.com| 国产精品偷伦免费视频观看的| 2018中文字幕一区二区三区| 懂色av影视一区二区三区| 都市激情亚洲色图| 亚洲欧洲日产国码av系列天堂| 亚洲色图25p| 亚洲欧美日韩综合| 91av在线看| 午夜精品国产精品大乳美女| 91免费精品国偷自产在线| 91成人福利在线| 2019国产精品自在线拍国产不卡| 亚洲人成电影在线观看天堂色| 亚洲性69xxxbbb| 欧美日韩国产成人在线观看| 国产欧美亚洲视频| 性欧美xxxx交| 黑人巨大精品欧美一区二区一视频| 欧美在线视频在线播放完整版免费观看| 国产精品一区二区女厕厕| 成年无码av片在线| 亚洲精品aⅴ中文字幕乱码| 精品一区二区电影| 国产精品午夜国产小视频| 91精品国产91久久| 欧美富婆性猛交| 青青草国产精品一区二区| 亚洲伊人久久综合| 夜夜嗨av一区二区三区免费区| 91经典在线视频| 国产精品福利小视频| 91精品国产自产在线| 亚洲大尺度美女在线| 欧美一级bbbbb性bbbb喷潮片| 久久久免费在线观看| 欧美成人精品激情在线观看| 91最新国产视频| 亚洲专区国产精品| 欧美成人一区二区三区电影| 亚洲精品动漫100p| 精品无人区乱码1区2区3区在线| 日韩毛片中文字幕| 国产精品一二三在线| 日本精品va在线观看| 美女性感视频久久久| 久久乐国产精品| 日本不卡视频在线播放| 日韩精品中文字| 国语对白做受69| 欧美黑人巨大精品一区二区| 欧美肥臀大乳一区二区免费视频| 国产精品高清免费在线观看| 亚洲精品中文字幕女同| 91tv亚洲精品香蕉国产一区7ujn| 亚洲色图校园春色| 97国产在线观看| 欧美性猛交xxxx偷拍洗澡| 欧美黑人xxx| 欧美xxxx做受欧美.88| 日韩美女视频免费在线观看| 欧美成人h版在线观看| 中文字幕国内精品| 91大神福利视频在线| 国产亚洲精品久久久久久牛牛| 亚洲天堂开心观看| 日韩成人av在线播放| 久久久女人电视剧免费播放下载| 欧美日韩免费在线| 国产xxx69麻豆国语对白| 日韩欧美黄色动漫| 久久久久亚洲精品| 日韩久久免费电影| 欧美黄色小视频| 91精品国产高清久久久久久久久| 欧美日韩成人免费| 91av在线视频观看| 亚洲国产精品99久久| 欧美日韩精品在线观看| 日本欧美在线视频| 久久九九国产精品怡红院| 中文字幕日韩视频| 最近更新的2019中文字幕| 日韩免费观看av| 奇门遁甲1982国语版免费观看高清| 国产91在线高潮白浆在线观看| 97涩涩爰在线观看亚洲| 国产精品 欧美在线| 欧美黑人xxx| 国产欧美中文字幕| 亚洲欧美999| 91极品女神在线| 国产亚洲免费的视频看| 欧美午夜电影在线| 92版电视剧仙鹤神针在线观看| 欧美国产日韩一区二区| 亚洲精品美女久久久久| 国产精品久久久久久久app| 亚洲a∨日韩av高清在线观看| 精品国内产的精品视频在线观看| 国产精品视频最多的网站| 欧美午夜精品久久久久久人妖| 国产精品网址在线| 久久精品国产v日韩v亚洲| 亚洲性猛交xxxxwww| 久99九色视频在线观看| 色偷偷9999www| 97在线视频国产| 精品国产视频在线| 91成人福利在线| 亚洲在线第一页| 国产精品成av人在线视午夜片| 亚洲免费视频观看| 亚洲欧美日韩视频一区| 日韩av在线网页| 亚洲剧情一区二区| 国产一区二区三区四区福利| 欧美成人精品不卡视频在线观看| 成人亚洲欧美一区二区三区| 欧美日韩高清在线观看| 国产一区二区动漫| 久久久之久亚州精品露出| 在线色欧美三级视频| 成人黄色中文字幕| 日韩在线视频播放|