基于Promise微信小程序http请求,轻便,小巧,api友好,功能丰富
- 支持Promise API
- 拦截请求和响应
- 转换请求和响应数据
- 取消请求
- 自动转换为JSON数据
- 超时请求
- 告别callback
- 支持默认请求前缀
- 支持并发请求
yarn add wechat-request
npm install wechat-request --save
import wxRequest from 'wechat-request';
首先来一个简单的get
请求
// 向具有给定ID的用户发出请求
wxRequest.get('/user?id=12345')
.then(function (response) {
console.log(response);
})
.catch(function (error) {
console.log(error);
});
// 可选地,上面的请求也可以按照
wxRequest.get('/user', {
params: {
id: 'number'
}
}).then(function (response) {
console.log(response);
}).catch(function (error) {
console.log(error);
});
// 想要使用 async/await? 将`async`关键字添加到外部函数/method
async function getUser() {
try {
const response = await wxRequest.get('/user?ID=12345');
console.log(response);
} catch (error) {
console.error(error);
}
}
多种方法使用async/waait,开启代码便捷、畅快之旅
接着再来一个post
请求
wxRequest.post('/user', {
firstname : 'firstname',
lastname : 'lastname'
}).then(function (response) {
console.log(response);
}).catch(function (error) {
console.log(error);
});
执行多并发请求例子
function getUserAccount() {
return wxRequest.get('/user/12345');
}
function getUserPermissions() {
return wxRequest.get('/user/12345/permissions');
}
wxRequest.all([getUserAccount(), getUserPermissions()])
.then(response =>{
// dosoming ...
});
当然除了常见的get
,post
其他的请求也统一封装
wxRequest.request(config)
wxRequest.get(url[, config])
wxRequest.delete(url[, config])
wxRequest.head(url[, config])
wxRequest.options(url[, config])
wxRequest.post(url[, data[, config]])
wxRequest.put(url[, data[, config]])
wxRequest.patch(url[, data[, config]])
note: 当使用别名方法
url
时,method
和data
属性不需要在config中指定。
使用场景用户请求需要token,或者地址前缀,一次配置,省时省心。
wxRequest.defaults.baseURL = 'https://api.example.com';
wxRequest.defaults.headers['Authorization'] = AUTH_TOKEN;
wxRequest.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
MIT