【微信小程序】对微信http请求API的封装,方便对错误码进行处理
| /** | |
| * App 微信配置文件app.js | |
| * author: nujey | |
| * versions: 1.0.0 | |
| */ | |
| App({ | |
| /** | |
| * @param {Object} options 调用的时候传入的参数对象 | |
| */ | |
| ajax: function (options) { | |
| // 把app的this重新保存 | |
| const wx_this = this | |
| // 请求过渡加载过程 | |
| // showLoading是微信自带的api 就是菊花转转转的请求过程 | |
| wx.showLoading({ | |
| title: '加载中', | |
| }) | |
| // 把调用的时候传入的url和小程序的域名拼接 | |
| // 得到 调用接口的地址 | |
| // this.globalData.apiHost 是获取到全局数据下面的接口域名 | |
| options.url = this.globalData.apiHost + options.url; | |
| return new Promise(function(resolve, reject) { | |
| // 发起微信请求 | |
| wx.request({ | |
| method: options.method, | |
| url: options.url, | |
| data: options.data, | |
| success: (result) => { | |
| wx.hideLoading() | |
| // http请求时200的时候 | |
| if (result.statusCode === 200) { | |
| // 这里是请求到的数据的code为成功的时候 可以根据自己的情况来定 100是自定义的 后台返回成功 | |
| if (result.data.code === 100) { | |
| resolve(result) | |
| } else if (result.data.code === 101) { | |
| // 这里的101 不是幛光101 是一个后台返回101的时候 证明微信登陆已经过时 需要重新登录一下 | |
| app.login(function () { | |
| that.onLoad({ id: that.data.id }); | |
| }); | |
| } else { | |
| // 其余的错误信息和code码 可以根据具体情况来定义title | |
| wx.showModal({ | |
| title: result.data.code.toString(), | |
| content: result.data.hint, | |
| showCancel: false, | |
| }) | |
| } | |
| } else { | |
| // http请求错误信息处理 微信自带的弹出框 | |
| wx.showModal({ | |
| title: '提示', | |
| content: '服务器错误,请联系客服', | |
| showCancel: false, | |
| }) | |
| } | |
| }, | |
| }) | |
| }) | |
| } | |
| }) | |
| // 调用 | |
| // 在每个页面的page前面会有一个 app = getApp() 获取app实例 | |
| const app = getApp() | |
| page({ | |
| // 比如我们在onLoad的时候 | |
| onLoad: function() { | |
| const params = { | |
| token: '...', | |
| id: '...', | |
| } | |
| app.ajax(params).then((result) => { | |
| // 处理数据 | |
| }) | |
| } | |
| }) | |
| // 具体的情况可以自己来修改一下 | |
| // 大佬们勿嘲风 小白上路 |
原文地址是我的github地址:求个星星~~~~· https://github.com/nujey/wx-request-ajax/blob/master/wx-request-ajax.js
【微信小程序】对微信http请求API的封装,方便对错误码进行处理的更多相关文章
- 微信小程序的ajax数据请求wx.request
微信小程序的ajax数据请求,很多同学找不到api在哪个位置,这里单独把小程序的ajax请求给列出来,微信小程序的请求就是wx.request这个api,wx.request(一些对象参数),微信小程 ...
- 微信小程序城市定位(百度地图API)
概述 微信小程序提供一些API(地址)用于获取当前用户的地理位置等信息,但无论是wx.getLocation,还是wx.chooseLocation均没有单独的字段表示国家与城市信息,仅有经纬度信息. ...
- 微信小程序request(ajax)接口请求封装
微信小程序request(ajax)接口请求封装 最近在进行小程序的编写,需要调用后端接口,经常要用到wx.request方法,所以就自己封装了一下,简化一下代码,如果能给大家提供帮助更好,在封装的时 ...
- 微信小程序之微信登陆 —— 微信小程序教程系列(20)
简介: 微信登陆,在新建一个微信小程序Hello World项目的时候,就可以看到项目中出现了我们的微信头像,其实这个Hello World项目,就有一个简化版的微信登陆.只不过是,还没有写入到咱们自 ...
- 微信小程序与微信公众号同一用户登录问题
微信小程序与微信公众号同一用户登录问题 最近在做微信小程序与微信公众号登录合并的接口.整理相关资料以及个人认识的心得写了这篇文章与大家一起分享. 首先,简单说下我遇到的问题是我们的程序调用微信小程序得 ...
- 微信小程序结合微信公众号进行消息发送
微信小程序结合微信公众号进行消息发送 由于小程序的模板消息已经废弃了,官方让使用订阅消息功能.而订阅消息的使用限制比较大,用户必须得订阅.需要获取用户同意接收消息的权限.用户必须得和小程序有交互的时候 ...
- [转]微信小程序、微信公众号、H5之间相互跳转
本文转自:https://www.cnblogs.com/colorful-paopao1/p/8608609.html 转自慕课网 一.小程序和公众号 答案是:可以相互关联. 在微信公众号里可以添加 ...
- 微信小程序、微信公众号、H5之间相互跳转
转自慕课网 一.小程序和公众号 答案是:可以相互关联. 在微信公众号里可以添加小程序. 图片有点小,我把文字打出来吧: 可关联已有的小程序或快速创建小程序.已关联的小程序可被使用在自定义菜单和模版消息 ...
- 微信小程序(微信应用号)开发ide安装解决方法
这两天整个技术圈都炸锅了,微信小程序(微信应用号)发布内测,首批200家收到邀请,但是没受邀请的同学,也不用担心,下面介绍一下解决方法. 首先需要下载ide,昨天只需要下载0.9版本的编辑器并替换文件 ...
- 微信小程序(原名微信应用号)开发工具0.9版安装教程
微信小程序全称微信公众平台·小程序,原名微信公众平台·应用号(简称微信应用号) 声明 微信小程序开发工具类似于一个轻量级的IDE集成开发环境,目前仅开放给了少部分受微信官方邀请的人士(据说仅200个名 ...
随机推荐
- 怎样把Linux的私钥文件id_rsa转换成putty的ppk格式
在Linux VPS下产生的私钥文件putty是不认识的,putty只认识自己的ppk格式,要在这两种格式之间转换,需要PuTTYgen这个程序. puttygen是putty的配套程序,putty的 ...
- KVM之八:快照创建、恢复与删除
kvm虚拟机默认使用raw格式的镜像格式,性能最好,速度最快,它的缺点就是不支持一些新的功能,如支持镜像,zlib磁盘压缩,AES加密等.要使用镜像功能,磁盘格式必须为qcow2.下面开始kvm虚拟机 ...
- 自动化制作.framework
1.生成.framework前的配置工作详见:http://www.cnblogs.com/huangzs/p/8029258.html 2. 将以下脚本粘贴进去,修改FMK_NAME. p.p1 { ...
- Intellij Idea下tomcat设置自动编译
*eclipse默认tomcat下是自动完成编译:而Intellij Idea默认tomcat下不是自动完成编译,从如下开始设置: 进入"settings",如下图找到" ...
- springmvc与freemarker的整合
官方简介:FreeMarker 是一款 模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页,电子邮件,配置文件,源代码等)的通用工具. 它不是面向最终用户的,而是一个Java ...
- JavaScript(第三天)【数据类型】
学习要点: 1.typeof操作符 2.Undefined类型 3.Null类型 4.Boolean类型 5.Number类型 6.String类型 7.Object类型 ECMAScript中有5种 ...
- python学习笔记-问题
1.字典按照值进行排序输出 2.返回函数-闭包的使用
- string类的简洁版实现
说是原创,差不多算是转载了,我也是看了好多大牛的写法,大牛的建议,自己加一总结,形成代码: 实现一个简洁版的string类,我觉得,下面的也够了:另外需要参见另外的写法: http://blog.cs ...
- nyoj 概率计算
概率计算 时间限制:1000 ms | 内存限制:65535 KB 难度:1 描述 A和B两个人参加一场答题比赛.比赛的过程大概是A和B两个人轮流答题,A先答.一旦某人没有正确回答问题,则对手 ...
- nyoj 矩形个数
矩形的个数 时间限制:1000 ms | 内存限制:65535 KB 难度:1 描述 在一个3*2的矩形中,可以找到6个1*1的矩形,4个2*1的矩形3个1*2的矩形,2个2*2的矩形,2个3 ...