Files
weRequest/example/request.ts

95 lines
4.2 KiB
TypeScript
Raw Permalink Normal View History

2019-04-01 17:54:56 +08:00
import weRequest from '../src/index'
2018-04-19 15:25:31 +08:00
weRequest.init({
2018-09-24 21:58:20 +08:00
// [可选] 存在localStorage的session名称且CGI请求的data中会自动带上以此为名称的session值可不配置默认为session
2018-04-19 15:25:31 +08:00
sessionName: "session",
2018-09-24 21:58:20 +08:00
// [可选] 请求URL的固定前缀可不配置默认为空
2017-07-31 17:23:46 +08:00
urlPerfix: "https://www.example.com/",
2018-09-24 21:58:20 +08:00
// [必填] 触发重新登录的条件res为CGI返回的数据
loginTrigger: function (res: any) {
2017-07-31 17:23:46 +08:00
// 此处例子当返回数据中的字段errcode等于-1会自动触发重新登录
return res.errcode == -1;
2018-04-19 15:25:31 +08:00
},
2018-09-24 21:58:20 +08:00
// [必填] 用code换取session的CGI配置
2018-04-19 15:25:31 +08:00
codeToSession: {
2018-09-24 21:58:20 +08:00
// [必填] CGI的URL
2018-04-19 15:25:31 +08:00
url: 'user/login',
2018-09-24 21:58:20 +08:00
// [可选] 调用改CGI的方法可不配置默认为GET
2018-04-19 15:25:31 +08:00
method: 'GET',
2018-09-24 21:58:20 +08:00
// [可选] CGI中传参时存放code的名称此处例子名称就是code可不配置默认值为code
2018-04-19 15:25:31 +08:00
codeName: 'code',
2018-09-24 21:58:20 +08:00
// [可选] 登录接口需要的其他参数;可不配置,默认为{}
2018-04-19 15:25:31 +08:00
data: {},
2018-09-24 21:58:20 +08:00
// [必填] CGI中返回的session值
2018-04-19 15:25:31 +08:00
success: function (res) {
// 此处例子CGI返回数据中的字段session即为session值
return res.session;
},
2018-09-24 21:58:20 +08:00
// [可选] 接口失败的回调,可不配置,默认为弹窗报错
2018-04-19 15:25:31 +08:00
fail: function(obj, res) {
}
},
2018-09-24 21:58:20 +08:00
// [可选] 登录重试次数当连续请求登录接口返回失败次数超过这个次数将不再重试登录可不配置默认为重试3次
2018-04-19 15:25:31 +08:00
reLoginLimit: 2,
2018-09-24 21:58:20 +08:00
// [必填] 触发请求成功的条件
successTrigger: function (res: any) {
2018-04-19 15:25:31 +08:00
// 此处例子当返回数据中的字段errcode等于0时代表请求成功其他情况都认为业务逻辑失败
return res.errcode == 0;
},
2018-09-24 21:58:20 +08:00
// [可选] 成功之后返回数据;可不配置
successData: function (res: any) {
2018-04-19 15:25:31 +08:00
// 此处例子返回数据中的字段data为业务接受到的数据
return res.data;
},
2018-09-24 21:58:20 +08:00
// [可选] 当CGI返回错误时弹框提示的标题文字
errorTitle: function(res: any) {
2018-04-19 15:25:31 +08:00
// 此处例子当返回数据中的字段errcode等于0x10040730时错误弹框的标题是“温馨提示”其他情况下则是“操作失败”
return res.errcode == 0x10040730 ? '温馨提示' : '操作失败'
},
2018-09-24 21:58:20 +08:00
// [可选] 当CGI返回错误时弹框提示的内容文字
errorContent: function(res: any) {
2018-04-19 15:25:31 +08:00
// 此处例子返回数据中的字段msg为错误弹框的提示内容文字
return res.msg ? res.msg : '服务可能存在异常,请稍后重试'
},
2018-09-24 21:58:20 +08:00
// [可选] 当出现CGI错误时统一的回调函数这里可以做统一的错误上报等处理
2018-04-19 15:25:31 +08:00
errorCallback: function(obj, res) {
// do some report
},
// [可选] 当出现错误时弹框是否显示重试按钮默认为false
errorRetryBtn: true,
2018-09-24 21:58:20 +08:00
// [可选] 是否需要调用checkSession验证小程序的登录态过期可不配置默认为false
2018-04-19 15:25:31 +08:00
doNotCheckSession: true,
2018-09-24 21:58:20 +08:00
// [可选] 上报耗时的函数name为上报名称startTime为接口调用开始时的时间戳endTime为接口返回时的时间戳
2018-04-19 15:25:31 +08:00
reportCGI: function(name, startTime, endTime, request) {
//wx.reportAnalytics(name, {
// time: endTime - startTime
//});
//request({
// url: 'reportCGI',
// data: {
// name: name,
// cost: endTime - startTime
// },
// fail: function() {
//
// }
//})
console.log(name + ":" + (endTime - startTime));
},
2018-09-24 21:58:20 +08:00
// [可选] 提供接口的mock若不需使用请设置为false
2018-04-19 15:25:31 +08:00
mockJson: require("../../mock.json"),
2018-09-24 21:58:20 +08:00
// [可选] 所有请求都会自动带上globalData里的参数
2017-11-23 19:45:53 +08:00
globalData: function() {
2018-04-19 15:25:31 +08:00
return {
version: getApp().version
}
2018-09-24 21:58:20 +08:00
},
// [可选] session本地缓存时间(单位为ms),可不配置,默认不设置本地缓存时间
sessionExpireTime: 24 * 60 * 60 * 1000,
// [可选] session本地缓存时间存在Storage中的名字可不配置默认为 sessionExpireKey
sessionExpireKey: "sessionExpireKey"
2018-04-19 15:25:31 +08:00
})
2019-04-01 17:54:56 +08:00
export default weRequest;