微信小程序使用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 相关文章推荐
用js判断用户浏览器是否是XP SP2的IE6
Mar 08 Javascript
jquery中event对象属性与方法小结
Dec 18 Javascript
JQuery结合CSS操作打印样式的方法
Dec 24 Javascript
jquery实现的树形目录实例
Jun 26 Javascript
javascript+HTML5的canvas实现七夕情人节3D玫瑰花效果代码
Aug 04 Javascript
JavaScript电子时钟倒计时
Jan 09 Javascript
JS实现简单的右下角弹出提示窗口完整实例
Jun 21 Javascript
JS实现本地存储信息的方法(基于localStorage与userData)
Feb 18 Javascript
javaScript日期工具类DateUtils详解
Dec 08 Javascript
微信小程序实现漂亮的弹窗效果
May 26 Javascript
electron + vue项目实现打印小票功能及实现代码
Nov 25 Javascript
基于layui内置模块(element常用元素的操作)
Sep 20 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
php错误、异常处理机制(补充)
2012/05/07 PHP
浅谈apache和nginx的rewrite的区别
2013/02/22 PHP
php表单请求获得数据求和示例
2014/05/15 PHP
php使用MySQL保存session会话的方法
2015/06/18 PHP
JavaScript全局函数使用简单说明
2011/03/11 Javascript
Jquery 数据选择插件Pickerbox使用介绍
2012/08/24 Javascript
简易js代码实现计算器操作
2013/04/15 Javascript
js固定DIV高度,超出部分自动添加滚动条的简单方法
2013/07/10 Javascript
jquery实现标签上移、下移、置顶
2015/04/26 Javascript
AngularJS之依赖注入模拟实现
2016/08/19 Javascript
SpringMVC+bootstrap table实例详解
2017/06/02 Javascript
jQuery+C#实现参数RSA加密传输功能【附jsencrypt.js下载】
2017/06/26 jQuery
js用类封装pop弹窗组件
2017/10/08 Javascript
微信上传视频文件提示(推荐)
2018/11/22 Javascript
vue v-for 点击当前行,获取当前行数据及event当前事件对象的操作
2020/09/10 Javascript
python局域网ip扫描示例分享
2014/04/03 Python
跟老齐学Python之集成开发环境(IDE)
2014/09/12 Python
python Django模板的使用方法
2016/01/14 Python
python嵌套函数使用外部函数变量的方法(Python2和Python3)
2016/01/31 Python
用十张图详解TensorFlow数据读取机制(附代码)
2018/02/06 Python
python实现聚类算法原理
2018/02/12 Python
flask框架单元测试原理与用法实例分析
2019/07/23 Python
雅诗兰黛香港官网:Estee Lauder香港
2017/09/26 全球购物
Boom手表官网:瑞典手表品牌,设计你的手表
2019/03/11 全球购物
澳大利亚珠宝商:Shiels
2019/10/06 全球购物
法国亚马逊官方网站:Amazon.fr
2020/12/19 全球购物
小区停车场管理制度
2014/01/27 职场文书
高中班级口号
2014/06/09 职场文书
一份文言文检讨书
2014/09/13 职场文书
向国旗敬礼活动总结范文2014
2014/09/27 职场文书
辩论赛主持人开场白
2015/05/29 职场文书
百年校庆感言
2015/08/01 职场文书
2016幼儿园毕业感言
2015/12/08 职场文书
Python中非常使用的6种基本变量的操作与技巧
2022/03/22 Python
使用Mysql计算地址的经纬度距离和实时位置信息
2022/04/29 MySQL
Java版 单机五子棋
2022/05/04 Java/Android