微信小程序前端promise封装代码实例


Posted in Javascript onAugust 24, 2019

这篇文章主要介绍了微信小程序前端promise封装代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

代码如下

config.js

const config = {
   base_url_api : "https://douban.uieee.com/v2/movie/",
}

export {config}

http.js

import { config } from "../config";
class HTTP {
  requset({ url, method = "GET", data = {} }) {
    const promise = new Promise((resolve, reject) => {
      wx.request({
        url: config.base_url_api + url,
        data,
        method,
        header: {
          'Content-Type': 'json'
        },
        success: res => {
          //状态码 toString() 转成字符串
          const statusCode = res.statusCode.toString();

          if (statusCode.startsWith("2")) {
            resolve(res.data)
          } else {
            this._show_error();
          }
        },
        fail: res => {
          reject(err);
          this._show_error();
        }
      })
    })
    return promise;
  }
  _show_error() {
    wx.showToast({
      title: '网络错误',
      icon: 'none'
    })
  }
}
export { HTTP }

model/movie.js

import {HTTP} from "../utils/http";
class MovieModel extends HTTP{
  getInTheaters(){
    return this.requset({
      url:"in_theaters"
    })
  }
  getTop250(){
    return this.requset({
      url:"top250"
    })
  }
  getComingSoon(){
    return this.requset({
      url:"coming_soon"
    })
  }
}
export {MovieModel};

pages/index/index.js

const app = getApp();
import {MovieModel} from "../../model/movie";
const movieModel = new MovieModel();
Page({
 onLoad(){
  // movieModel.getInTheaters().then(res=>{
  //  console.log(res)
  // })
  const inTheaters = movieModel.getInTheaters()
  const top250 = movieModel.getTop250();
  const comingSoon = movieModel.getComingSoon();
  Promise.all([inTheaters,top250,comingSoon]).then(res=>{
   let[inTheaters,top250,comingSoon] = res;
   console.log(inTheaters)
  })
 }
})

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

Javascript 相关文章推荐
阻止JavaScript事件冒泡传递(cancelBubble 、stopPropagation)
May 08 Javascript
node.js+Ajax实现获取HTTP服务器返回数据
Nov 26 Javascript
JavaScript动态插入CSS的方法
Dec 10 Javascript
微信小程序 开发工具快捷键整理
Oct 31 Javascript
javascript中活灵活现的Array对象详解
Nov 30 Javascript
Vue.js基础指令实例讲解(各种数据绑定、表单渲染大总结)
Jul 03 Javascript
全面解析jQuery中的$(window)与$(document)的用法区别
Aug 15 jQuery
JavaScript分步实现一个出生日期的正则表达式
Mar 22 Javascript
浅谈 Webpack 如何处理图片(开发、打包、优化)
May 15 Javascript
layui清空,重置表单数据的实例
Sep 12 Javascript
微信小程序进入广告实现代码实例
Sep 19 Javascript
vue+elementui 实现新增和修改共用一个弹框的完整代码
Jun 08 Vue.js
node获取客户端ip功能简单示例
Aug 24 #Javascript
js针对图片加载失败的处理方法分析
Aug 24 #Javascript
js prototype和__proto__的关系是什么
Aug 23 #Javascript
帮你彻底搞懂JS中的prototype、__proto__与constructor(图解)
Aug 23 #Javascript
JS 实现发送短信验证码的“59秒后重新发送验证短信”功能
Aug 23 #Javascript
微信小程序swiper禁止用户手动滑动代码实例
Aug 23 #Javascript
Node.JS枚举统计当前文件夹和子目录下所有代码文件行数
Aug 23 #Javascript
You might like
WINDOWS下php5.2.4+mysql6.0+apache2.2.4+ZendOptimizer-3.3.0配置
2008/03/28 PHP
PHP导航下拉菜单的实现如此简单
2013/09/22 PHP
ThinkPHP3.1新特性之多层MVC的支持
2014/06/19 PHP
PHP pthreads v3下的Volatile简介与使用方法示例
2020/02/21 PHP
php swoft框架实例用法
2020/12/22 PHP
jquery 表单取值常用代码
2009/12/22 Javascript
jQuery获得内容和属性方法及示例
2013/12/02 Javascript
JavaScript的原型继承详解
2015/02/15 Javascript
jQuery网页右侧广告跟随滚动代码分享
2020/04/20 Javascript
很全面的JavaScript常用功能汇总集合
2016/01/22 Javascript
js类式继承与原型式继承详解
2016/04/07 Javascript
onclick和onblur冲突问题的快速解决方法
2016/04/28 Javascript
前端开发之CSS原理详解
2017/03/11 Javascript
vue-router实现webApp切换页面动画效果代码
2017/05/25 Javascript
React根据宽度自适应高度的示例代码
2017/10/11 Javascript
vue.js过滤器+ajax实现事件监听及后台php数据交互实例
2018/05/22 Javascript
解决Layui当中的导航条动态添加后渲染失败的问题
2019/09/25 Javascript
Python中使用tarfile压缩、解压tar归档文件示例
2015/04/05 Python
python smtplib模块发送SSL/TLS安全邮件实例
2015/04/08 Python
为Python程序添加图形化界面的教程
2015/04/29 Python
Python采用Django制作简易的知乎日报API
2016/08/03 Python
Python中文件I/O高效操作处理的技巧分享
2017/02/04 Python
解决Linux系统中python matplotlib画图的中文显示问题
2017/06/15 Python
python+splinter自动刷新抢票功能
2018/09/25 Python
使用tensorflow框架在Colab上跑通猫狗识别代码
2020/04/26 Python
Python openpyxl模块实现excel读写操作
2020/06/30 Python
Jeep牧马人、切诺基和自由人零配件:4 Wheel Drive Hardware
2017/07/02 全球购物
台湾屈臣氏网路商店:Watsons台湾
2020/12/29 全球购物
香奈儿美国官网:CHANEL美国
2020/05/20 全球购物
保护母亲河倡议书
2014/04/14 职场文书
护士上岗前培训自我鉴定
2014/04/20 职场文书
领导班子四风对照检查材料
2014/09/23 职场文书
小学假期安全广播稿
2014/09/28 职场文书
美容院合作经营协议书
2014/10/10 职场文书
信用卡工资证明范本
2015/06/19 职场文书
如何写好一份优秀的工作总结?
2019/06/21 职场文书