在微信小程序的JS腳本中使用Promise來(lái)優(yōu)化函數(shù)處理

作者:網(wǎng)站建設(shè)公司 來(lái)源:微信小程序日期:2020-11-11 瀏覽: 次

網(wǎng)站建設(shè) - 建站教程 - 微信小程序 - 在微信小程序的JS腳本中使用Promise來(lái)優(yōu)化函數(shù)處理

  在我們傳統(tǒng)的Javascript開發(fā)函數(shù)編寫中,我們習(xí)慣了回調(diào)函數(shù)的處理,不過(guò)隨著回調(diào)函數(shù)的增多,以及異步處理的復(fù)雜性等原因,代碼越來(lái)越難讀,因此誕生了使用Promise來(lái)優(yōu)化JS函數(shù)處理的需求,引入Promise確實(shí)能夠很好的解決異步回調(diào)函數(shù)的可讀性等問題,同時(shí)也使得我們調(diào)用的時(shí)候代碼簡(jiǎn)潔一些,本文介紹如何在小程序的JS代碼里面使用Promise來(lái)封裝一些函數(shù)的做法。

  1、小程序傳統(tǒng)的回調(diào)處理

  例如我們生成一個(gè)小程序,里面的app.js里面就自動(dòng)帶有一個(gè)getUserInfo的函數(shù),這個(gè)是使用傳統(tǒng)模式的回調(diào)函數(shù)。

  //app.js

  App({

  onLaunch: function () {

  //調(diào)用API從本地緩存中獲取數(shù)據(jù)

  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{

  //調(diào)用登錄接口

  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

  }

  })

  這種是通過(guò) 傳入一個(gè)cb的回調(diào)函數(shù)進(jìn)行處理,使用的時(shí)候?yàn)榱税踩?,還需要進(jìn)一步判斷其類型是否為函數(shù):typeof cb == "function",這種處理還是相對(duì)比較易懂。

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

  asyncFunc1(function(){

  //...

  asyncFunc2(function(){

  //...

  asyncFunc3(function(){

  //...

  asyncFunc4(function(){

  //...

  asyncFunc5(function(){

  //...

  });

  });

  });

  });

  });

  如果我們改用Promise來(lái)處理,那么進(jìn)行一層簡(jiǎn)單的包裝即可。

  function asyncFunc1(){

  return new Promise(function (resolve, reject) {

  //...

  })

  }

  2、Promise的使用介紹

  Promise的使用相對(duì)比較簡(jiǎn)單,我們?nèi)腴T可以參考下相關(guān)介紹:阮一峰 promise入門,如果我們?cè)贘S函數(shù)里面引入它的話,那么需要包含對(duì)應(yīng)的javascript組件

  我們可以在Github上下載對(duì)應(yīng)的組件JS,引入小程序項(xiàng)目即可:es6-promise

  我們?yōu)榱朔奖悖陧?xiàng)目中創(chuàng)建一個(gè)輔助類utils.js,然后在其中引入Promise的腳本,如下所示。

  const Promise = require('./Promise') 
然后在APP.js里面,我們修改原來(lái)的getUserInfo函數(shù)如下

  //app.js

  const utils = require('./utils/util.js')

  App({

  onLaunch: function() {

  //調(diào)用API從本地緩存中獲取數(shù)據(jù)

  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)

  })

  })

  },

  //獲取系統(tǒng)信息

  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);

  }

  })

  }

  })

  },

  //全局對(duì)象

  globalData: {

  userInfo: null,

  systemInfo: null

  },

  utils

  })

  我們看到,所有原先的函數(shù),我們?nèi)绻枰隤romise處理的話,增加一層的函數(shù)體即可。

  return new utils.Promise((resolve, reject) => {

  // 原來(lái)的函數(shù)體代碼

  }); 
這樣我們調(diào)用的時(shí)候,使用then函數(shù)進(jìn)行處理即可,類似下面的代碼。

  getUserInfo().then(user => this.setData({userInfo:user})).catch(console.log); 
引入這個(gè)Promise后,我們?yōu)榱诉M(jìn)一步實(shí)現(xiàn)代碼的重用,可以把一些常見的函數(shù)放到utils.js來(lái),這樣可以實(shí)現(xiàn)代碼的重用。

  //用戶登錄

  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請(qǐng)求方法

  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')

  }

  })

  })

  }

  然后發(fā)布對(duì)應(yīng)的接口,以供其他模塊使用即可。

  //發(fā)布的接口

  module.exports = {

  Promise,makeArray,getUserInfo,

  get:requstGet,post:requstPost,requst,decodeHtml,

  formatTime,getDateDiff

  }

  封裝好這些公用方法后,我們?cè)陧?yè)面里面進(jìn)行調(diào)用即可,調(diào)用的代碼如下所示(演示代碼從地址里面獲取數(shù)據(jù),并綁定到界面上)

  //使用Comprise的封裝函數(shù)展現(xiàn)

  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);

  });

  而如果我們使用原來(lái)的函數(shù),那么實(shí)現(xiàn)代碼如下所示。

  // 使用標(biāo)準(zhǔn)的wx.request函數(shù)實(shí)現(xiàn)展現(xiàn)

  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);

  }

  })

  如果對(duì)于復(fù)雜流程的函數(shù)處理,使用Promise來(lái)處理,會(huì)顯得更加簡(jiǎn)潔易讀。


企業(yè)網(wǎng)站建設(shè)一條龍
找零度飛易網(wǎng)絡(luò)公司-fslingdu所做php網(wǎng)站建設(shè)方案、網(wǎng)站設(shè)計(jì)網(wǎng)站制作北京上海深圳龍崗衢州蘭州常州東營(yíng)南通濟(jì)寧桂林淮安煙臺(tái)長(zhǎng)春無(wú)錫天津昆山蘇州合肥洛陽(yáng)昆明天津唐山泉州惠州萬(wàn)州新鄉(xiāng)商丘臺(tái)州哈爾濱太原攝影???/strong>隨州學(xué)校商丘廣東湖南廣西江西海南廣州企業(yè)中小企業(yè)武漢南山羅湖福田虎門肇慶汕尾汕頭廣州佛山成都杭州濟(jì)南重慶福州西安廈門昆山沈陽(yáng)青島徐州鄭州南京南寧長(zhǎng)沙大連淄博石家莊南昌溫州珠海番禺順德三水高明中山東莞合肥江門嘉興西寧大良容桂倫教勒流陳村均安杏壇龍江樂從北滘祖廟石灣南莊等地區(qū)企業(yè)網(wǎng)站建設(shè)(廣告)公司提供專業(yè)做網(wǎng)站價(jià)格規(guī)劃書及營(yíng)銷型網(wǎng)站制作,網(wǎng)站建設(shè)基礎(chǔ)知識(shí)
標(biāo)簽: 微信小程序

微信小程序   微信小程序

網(wǎng)站建設(shè)費(fèi)用

網(wǎng)站制作電話:137 1543 1176

網(wǎng)站開發(fā)QQ:378780108

E-mailsale@fslingdu.com如何制作網(wǎng)站QQ :378780108

網(wǎng)站建設(shè)服務(wù)

網(wǎng)站建設(shè)公司零度飛易是一家專業(yè)網(wǎng)站設(shè)計(jì),網(wǎng)站制作、seo優(yōu)化,網(wǎng)站推廣,網(wǎng)站建設(shè)的佛山網(wǎng)絡(luò)運(yùn)營(yíng)公司。零度飛易在家具網(wǎng)站建設(shè)小家電網(wǎng)站建設(shè)、服裝網(wǎng)站建設(shè)、電器網(wǎng)站建設(shè)、機(jī)械網(wǎng)站建設(shè)等行業(yè)的網(wǎng)站設(shè)計(jì)、網(wǎng)絡(luò)運(yùn)營(yíng)都得到行業(yè)認(rèn)可,在上海深圳、北京、廣州、佛山中山、東莞地區(qū)有著良好的口碑品牌的網(wǎng)站建設(shè)公司。我們的使命是打造創(chuàng)新型的網(wǎng)站建設(shè)企業(yè),能輕易地開展“互聯(lián)網(wǎng)+”業(yè)務(wù)、實(shí)現(xiàn)“互聯(lián)網(wǎng)+企業(yè)”的企業(yè)愿景。

Hi,Are you ready?

準(zhǔn)備好開始了嗎?
那就與我們?nèi)〉寐?lián)系吧

有一個(gè)互聯(lián)網(wǎng)項(xiàng)目想和我們談?wù)剢幔磕梢蕴顚懹疫叺谋砀?,讓我們了解您的?xiàng)目需求,這是一個(gè)良好的開始,我們將會(huì)盡快與你取得聯(lián)系。當(dāng)然也歡迎您給我們寫信或是打電話,讓我們聽到你的聲音!

零度飛易 互聯(lián)網(wǎng)整合營(yíng)銷

地址:佛山市順德區(qū)大良鳳翔商業(yè)廣場(chǎng)二座670

業(yè)務(wù)QQ:378780108

策劃專線:13715431176

E-mail:sale@fslingdu.com

合作意向表

您需要的服務(wù)

現(xiàn)有網(wǎng)站改版
我需要做微信營(yíng)銷
建設(shè)全新的企業(yè)網(wǎng)站
要找長(zhǎng)期合作公司,需要年度服務(wù)
我需要做購(gòu)物商城
我需要做系統(tǒng)平臺(tái)

您最關(guān)注的地方

對(duì)功能要求比較高
對(duì)設(shè)計(jì)創(chuàng)意要求比較高
需要可以購(gòu)物支付
搜索引擎排名

價(jià)格預(yù)算

1-3萬(wàn)3-5萬(wàn)5-8萬(wàn)8-10萬(wàn)10萬(wàn)以上大型項(xiàng)目需要招標(biāo)

原神乳液狂飙开襟网站mimei,正文和朋友换娶妻游戏,电影essuess,苏娅苏语棠元宵节md0217BD,安全隐私保护,高速低延迟,高质量真免费海外加速【可复制网址到浏览器中打开】 ,免费夜里18款禁用软粉色APP,果酱tv.app,1001个视角,poren HD,丕丕漫画网页登录页面入口免费