一级毛片视频在线观看-一级毛片视频免费-一级毛片视频播放-一级毛片看真人在线视频-国产高清在线精品一区a-国产高清在线精品一区二区

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

作者:網站建設公司 來源:微信小程序日期:2020-11-11 瀏覽:

網站建設 - 建站教程 - 微信小程序 - 在微信小程序的JS腳本中使用Promise來優化函數處理

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

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

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

  //app.js

  App({

  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.js

  const 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來處理,會顯得更加簡潔易讀。


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

網站建設費用

網站制作電話:137 1543 1176

網站開發QQ:378780108

E-mailsale@fslingdu.com如何制作網站QQ :378780108

網站建設服務

網站建設公司零度飛易是一家專業網站設計,網站制作、seo優化,網站推廣,網站建設的佛山網絡運營公司。零度飛易在家具網站建設小家電網站建設服裝網站建設電器網站建設機械網站建設等行業的網站設計、網絡運營都得到行業認可,在上海深圳北京廣州佛山中山東莞地區有著良好的口碑品牌的網站建設公司。我們的使命是打造創新型的網站建設企業,能輕易地開展“互聯網+”業務、實現“互聯網+企業”的企業愿景。

Hi,Are you ready?

準備好開始了嗎?
那就與我們取得聯系吧

有一個互聯網項目想和我們談談嗎?您可以填寫右邊的表格,讓我們了解您的項目需求,這是一個良好的開始,我們將會盡快與你取得聯系。當然也歡迎您給我們寫信或是打電話,讓我們聽到你的聲音!

零度飛易 互聯網整合營銷

地址:佛山市順德區大良鳳翔商業廣場二座670

業務QQ:378780108

策劃專線:13715431176

E-mail:sale@fslingdu.com

合作意向表

您需要的服務

現有網站改版
我需要做微信營銷
建設全新的企業網站
要找長期合作公司,需要年度服務
我需要做購物商城
我需要做系統平臺

您最關注的地方

對功能要求比較高
對設計創意要求比較高
需要可以購物支付
搜索引擎排名

價格預算

1-3萬3-5萬5-8萬8-10萬10萬以上大型項目需要招標

锕锕锕锕锕锕锕好疼免费视频| 性色AV极品无码专区亚洲| www.xx欧美大鸡巴| 女人被狂躁C到高潮视频| 真实的国产乱ⅩXXX66| 久久久久久精品免费免费麻辣| 亚洲欧美精品午睡沙发| 精品综合久久久久久97| 亚洲欧美一区二区成人片婷婷| 娇妻当着我的面被4P| 亚洲国产精品一区二区制服 | 久久久久亚洲AV成人片丁香| 亚洲码国产精品高潮在线| 精品国产乱码一区二区三区APP | 欧美日韩一区二区三区在线观看视 | 亚洲日韩片无码中文字幕| 精品少妇AY一区二区三区| 亚洲无人区一码二码三码区别| 久久久久国色AV免费观看性色| 一二三四在线观看免费中文 | 99国产精品久久久久久久成人热| 欧美VPSWINDOWS精品| JAPANESE护士高潮SEX| 日本爆乳丰满熟妇XXXX| 大鷄巴久久久久久久久久| 熟女少妇丰满一区二区| 国产精品白丝AV嫩草影院| 羞羞漫画十八禁啪啪漫画免费| 黑人性受XXXX黑人XYX性爽| 亚洲乱码日产精品BD| 久久久久久久波多野结衣高潮 | 欧美丰满熟妇XX猛交| 斑马视频电影免费观看| 上边一面亲下边一面膜的作用| 国产激情大臿免费视频| 亚洲AV日韩AV无码污污网站| 精品无码国产自产拍在线观看蜜桃| 亚洲一区二区三区在线观看网站 | 国产成人亚洲综合色影视| 亚洲 欧美 变态 另类 综合| 精品熟妇无码av免费久久| 永久免费不卡在线观看黄网站| 内射人妻无套中出无码| 北条麻妃在线一区二区| 天堂种子在线WWW网| 国精无码欧精品亚洲一区| 亚洲综合AV在线在线播放| 男人的天堂AV网址| 催眠性指导OVA1一6集| 无遮挡又黄又刺激的视频| 精品无码人妻被多人侵犯AV| 中文字幕乱人伦高清视频 | 无码综合天天久久综合网色吧影院| 河南妇女毛深深的沟WCD| 尤物娇妻被NP高H| 欧洲一卡二卡三卡| 国产成人久久精品流白浆| 亚洲AV无码专区亚洲AV漫画 | 超级YIN荡的公司聚会| 无码人妻精品一区二区三区夜夜嗨| 娇妻被朋友征服中文字幕| 有人有在线观看的片资源| 人妻丰满AV无码中文字幕| 国产精品美女久久久免费| 亚洲熟妇无码AⅤ在线播放| 欧美成人精品三级网站下载 | 在线亚洲熟妇一区二区三| 日本漂亮妈妈7在观有限中子| 国产精品午夜无码AV体验区| 亚洲熟妇无码一区二区三区| 欧美日韩亚洲国产综合乱| 国产精品 高清 尿 小便 嘘嘘| 亚洲日本VA中文字幕| 欧美日韩一区二区三区精品视频在线| 国产成人无码免费看片软件| 亚洲日韩激情无码一区| 欧美最厉害的喷水VIDEOS| 国产精品亚洲综合一区在线观看| 亚洲中字幕日产AV片在线| 人与禽zozzo性伦| 豪妇荡乳1一5潘金莲2在线 | 国产成人无码午夜视频在线观看| 亚洲日韩在线中文字幕综合| 青青草无码精品伊人久久7| 国产欧美一区二区精品久久久| 在线观看亚洲AV| 私人医生H1忘记密码了怎么办| 久久WWW成人免费网站| 被滋润的娇妻疯狂呻吟| 亚洲成人AV免费| 琪琪女色窝窝777777| 国产揄拍国产精品| 99久久精品午夜一区二区| 午夜理论片免费播放| 男男激情H视频Gay片GV| 国产精品538一区二区在线| 尹人香蕉久久99天天拍| 双飞两个丰满少妇11P| 久久天堂无码AV网站| 东京热人妻无码人AV| 夜夜添无码一区二区三区| 少妇扒开腿让我爽了一夜| 久久久久无码国产精品一区| 公粗挺进了我的密道在线播放| 亚洲最新无码中文字幕久久| 色综合天天天天综合狠狠爱| 久久人妻AV一区二区软件| 贵阳40多岁熟女高潮呻吟| 在人线AV无码免费高潮喷水| 铜铜铜铜铜铜铜铜铜好多深| 蜜桃中文字日产乱幕4区| 国产精品自在线拍国产电影| 99V久久综合狠狠综合久久| 亚洲AV成人精品一区二区三区| 欧美人与动性XXXXX交性| 含羞草四叶草三叶草| 白嫩的18SEX少妇HD| 亚洲午夜无码久久久久小说 | 亚洲综合AV一区二区三区| 色综合天天综合网国产成人网| 久久人妻少妇偷人精品综合桃色| 国产成人精品视频网站| 97成人无码免费一区二区中文| 亚洲AV无码成人精品区H| 日本H纯肉无遮掩3D动漫在线观| 久久AV高清无码| 国产成人精选视频在线观看| 999在线视频精品免费播放观看| 亚洲成在人线AV中文字幕喷水| 日韩中文人妻无码不卡| 美女高潮黄又色高清视频免费| 国产偷窥熟女精品视频大全| 暴力调教一区二区三区| 野花影视免费观看电视剧| 午夜精品久久久久久久无码| 人妻无码一区二区三区四区| 久久亚洲国产成人精品性色| 国产麻豆天美果冻无码视频 | 西西4444WWW大胆无码| 人妻丰满熟妇AV无码区HD| 久久香蕉综合色一综合色88| 国产偷窥熟女精品视频大全| 潮喷无码正在播放| 中央气象台1一7天降水量预报图| 亚洲AV中文AⅤ无码AV浪潮| 少妇CHINA中国人妻VIDE| 女人扒下裤让男人桶到爽 | 成 人 黄 色 网 站 视频 S色| 永久免费看啪啪的网站| 亚洲爆乳AⅤ无码一区二区| 思思久久99热只有频精品66| 欧美性性性性性色大片免费的| 久久人人爽人人爽人人片DVD| 国产又猛又黄又爽| 跟40岁的少妇做一次就不硬了| CHINESE熟女老女人HD| 又大又粗又爽ΑA级毛片| 亚洲成AV人片在| 无码人妻斩一区二区三区| 日韩人妻无码精品专区90618| 欧美成人免费全部观看| 久久天天躁拫拫躁夜夜AV| 狠狠爱俺也去去就色| 国产精品无码一区二区三区免费| 大学生无套流白浆视频大全| BGMBGM浓毛老太太| 中文字幕无码久久一区| 亚洲香蕉成人AAAV在线网站| 亚洲AV无码国产精品色午友在线 | 免费看含羞草AV片成人网址| 久久精品国产免费观看三人同眠| 国产亚洲精品精品国产亚洲综合| 国产成人无码AⅤ片在线观看导航| 成人午夜福利免费体验区| FREEZEFRAME丰满少妇| 中文字幕乱码人妻无码久久| 野花社区日本免费图片| 亚洲人JIZZ日本人| 亚洲国产精品热久久| 亚洲AV成人无码一区在线观看| 我趁老师睡觉偷偷的脱她内裤 | 一二三四影视在线看片免费| 亚洲日韩一区二区三区波多野结衣 | 亚洲AV永久无码精品秋霞电影影| 无码人妻在线视频| 无码精品A∨在线观看十八禁| 天堂中文А√在线官网| 视频一区二区三区在线观看| 日韩人妻中文字幕2021视频| 日产一二三区别免费必看| 人妻夜夜添夜夜无码AV| 人妻少妇中文字幕乱码| 人妻熟妇乱又伦精品HD| 人妻的渴望波多野结衣| 人妻精油按摩BD高清中文字幕| 欧美精品人妻AⅤ在线观视频免费| 欧美VIDEOS另类色HDFR| 欧美丰满少妇人妻精品| 欧美人妻一区二区三区| 青青爽无码视频在线观看|