在微信小程序的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万以上大型项目需要招标