微信小程序使用Promise简化回调


Posted in Javascript onFebruary 06, 2018

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简化回调

简化回调

可以看到简化效果非常明显。

同样适用于网页或者nodejs等中。

参考

Promise 对象

源代码

tomfriwel/MyWechatAppDemo 的promisePage页面

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
关于event.cancelBubble和event.stopPropagation()的区别介绍
Dec 11 Javascript
jQuery.extend()的实现方式详解及实例
Jun 29 Javascript
JS控制阿拉伯数字转为中文大写示例代码
Sep 04 Javascript
express+mockjs实现模拟后台数据发送功能
Jan 07 Javascript
JavaScript常用截取字符串的三种方式用法区别实例解析
May 15 Javascript
在vue中获取token,并将token写进header的方法
Sep 26 Javascript
浅谈vuex actions和mutation的异曲同工
Dec 13 Javascript
如何解决.vue文件url引用文件的问题
Jan 18 Javascript
产制造追溯系统之通过微信小程序实现移动端报表平台
Jun 03 Javascript
vue+element搭建后台小总结 el-dropdown下拉功能
Apr 10 Javascript
jQuery实现颜色打字机的完整代码
Mar 19 jQuery
原生JavaScript实现购物车
Jan 10 Javascript
JS设计模式之命令模式概念与用法分析
Feb 06 #Javascript
使用selenium抓取淘宝的商品信息实例
Feb 06 #Javascript
vue一个页面实现音乐播放器的示例
Feb 06 #Javascript
使用百度地图实现地图网格的示例
Feb 06 #Javascript
js中的闭包学习心得
Feb 06 #Javascript
JS基于设计模式中的单例模式(Singleton)实现封装对数据增删改查功能
Feb 06 #Javascript
Vue仿今日头条实例详解
Feb 06 #Javascript
You might like
打造计数器DIY三步曲(中)
2006/10/09 PHP
详解php比较操作符的安全问题
2015/12/03 PHP
浅谈PHPANALYSIS提取关键字
2019/03/08 PHP
php实现断点续传大文件示例代码
2020/06/19 PHP
通过MSXML2自动获取QQ个人头像及在线情况(给初学者)
2007/01/22 Javascript
jQuery的实现原理的模拟代码 -1 核心部分
2010/08/01 Javascript
IE无法设置短域名下Cookie
2010/09/23 Javascript
基于jquery的web页面日期格式化插件
2011/11/15 Javascript
JS函数实现动态添加CSS样式表文件
2012/12/15 Javascript
ExtJS的拖拽效果示例
2013/12/09 Javascript
jQuery实现简单的间隔向上滚动效果
2015/03/09 Javascript
每天一篇javascript学习小结(Array数组)
2015/11/11 Javascript
javascript执行环境及作用域详解
2016/05/05 Javascript
Bootstrap基本组件学习笔记之导航(10)
2016/12/07 Javascript
axios基本入门用法教程
2017/03/25 Javascript
使用Bootstrap + Vue.js实现表格的动态展示、新增和删除功能
2017/11/27 Javascript
微信小程序自定义可滑动日历界面
2018/12/28 Javascript
vue router带参数页面刷新或回退参数消失的解决方法
2019/02/27 Javascript
javascript读取本地文件和目录方法详解
2020/08/06 Javascript
Python获取电脑硬件信息及状态的实现方法
2014/08/29 Python
pygame加载中文名mp3文件出现error
2017/03/31 Python
Python统计纯文本文件中英文单词出现个数的方法总结【测试可用】
2018/07/25 Python
Python如何爬取51cto数据并存入MySQL
2020/08/25 Python
利用CSS3实现平移动画效果示例代码
2016/10/12 HTML / CSS
Wiggle美国:英国骑行、跑步、游泳、铁人三项商店
2018/10/27 全球购物
一百多行代码实现react拖拽hooks
2021/03/23 Javascript
小学教师节活动方案
2014/01/31 职场文书
《路旁的橡树》教学反思
2014/04/07 职场文书
学生自我评语大全
2014/04/18 职场文书
小学生操行评语大全
2014/04/22 职场文书
小学五一劳动节活动总结
2015/02/09 职场文书
责任书范本大全
2015/05/11 职场文书
python中的plt.cm.Paired用法说明
2021/05/31 Python
动画《新网球王子 U-17 WORLD CUP》希腊队PV公开
2022/04/02 日漫
vue组件vue-esign实现电子签名
2022/04/21 Vue.js
Nginx如何配置多个服务域名解析共用80端口详解
2022/09/23 Servers