微信小程序前端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 相关文章推荐
HTML-CSS群中单选引发的“事件”
Mar 05 Javascript
jquery DOM操作 基于命令改变页面
May 06 Javascript
JavaScript.Encode手动解码技巧
Jul 14 Javascript
JS获取html对象的几种方式介绍
Dec 05 Javascript
JS实现模仿微博发布效果实例代码
Dec 16 Javascript
JS文本获得焦点清除文本文字的示例代码
Jan 13 Javascript
AngularJS ng-repeat数组有重复值的解决方法
Oct 23 Javascript
jstree单选功能的实现方法
Jun 07 Javascript
浅谈vue引用静态资源需要注意的事项
Sep 28 Javascript
Vue递归实现树形菜单方法实例
Nov 06 Javascript
回顾Javascript React基础
Jun 15 Javascript
React Native登录之指纹登录篇的示例代码
Nov 03 Javascript
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
PHP 和 XML: 使用expat函数(二)
2006/10/09 PHP
PHP中ADODB类详解
2008/03/25 PHP
PHP函数之日期时间函数date()使用详解
2013/09/09 PHP
PHP使用JSON和将json还原成数组
2015/02/12 PHP
PHP获取用户客户端真实IP的解决方案
2016/10/10 PHP
jquery 简单的进度条实现代码
2010/03/11 Javascript
不使用中间变量,交换int型的 a, b两个变量的值。
2010/10/29 Javascript
原生javascript兼容性测试实例
2013/07/01 Javascript
alert中断settimeout计时功能
2013/07/26 Javascript
JavaScript获取文本框内选中文本的方法
2015/02/20 Javascript
jQuery自动添加表单项的方法
2015/07/13 Javascript
jquery对象访问是什么及使用方法介绍
2016/05/03 Javascript
vue的props实现子组件随父组件一起变化
2016/10/27 Javascript
浅谈jquery页面初始化的4种方式
2016/11/27 Javascript
bootstrap可编辑下拉框jquery.editable-select
2017/10/12 jQuery
Vue-cli-webpack搭建斗鱼直播步骤详解
2017/11/17 Javascript
vue-cli webpack模板项目搭建及打包时路径问题的解决方法
2018/02/26 Javascript
解决vue+webpack打包路径的问题
2018/03/06 Javascript
GOJS+VUE实现流程图效果
2018/12/01 Javascript
JS中的算法与数据结构之栈(Stack)实例详解
2019/08/20 Javascript
vue router-link 默认a标签去除下划线的实现
2020/11/06 Javascript
JS实现炫酷轮播图
2020/11/15 Javascript
Python的Tornado框架异步编程入门实例
2015/04/24 Python
Linux上安装Python的PIL和Pillow库处理图片的实例教程
2016/06/23 Python
Tensorflow实现在训练好的模型上进行测试
2020/01/20 Python
Python转换字典成为对象,可以用"."方式访问对象属性实例
2020/05/11 Python
基于Python第三方插件实现西游记章节标注汉语拼音的方法
2020/05/22 Python
Python3 webservice接口测试代码详解
2020/06/23 Python
pytorch查看模型weight与grad方式
2020/06/24 Python
XD健身器材:Kevlar球、Crossfit健身球
2019/03/26 全球购物
客服端调用EJB对象的几个基本步骤
2012/01/15 面试题
高中校园广播稿
2014/01/11 职场文书
《孔繁森》教学反思
2014/04/17 职场文书
大学生作弊检讨书
2014/09/11 职场文书
详解python字符串驻留技术
2021/05/21 Python
vue中使用mockjs配置和使用方式
2022/04/06 Vue.js