一个轻量级微信小程序请求库。
通过 npm:
npm install daigo
发起一个 GET 请求:
const daigo = require('daigo');
// 向给定 id 的用户发起请求
daigo
.get('/user?id=12345')
.then(function (response) {
// 处理成功情况
console.log(response);
})
.catch(function (error) {
// 处理错误情况
console.log(error);
})
.finally(function () {
// 总是会执行
});
// 上述请求也可以按以下方式完成(可选)
daigo
.get('/user', {
data: {
id: 12345,
},
})
.then(function (response) {
console.log(response);
})
.catch(function (error) {
console.log(error);
})
.finally(function () {
// always executed
});
// 支持 async/await 用法
async function getUser() {
try {
const response = await daigo.get('/user?id=12345');
console.log(response);
} catch (error) {
console.error(error);
}
}
发起一个 POST 请求:
daigo
.post('/user', {
data: {
firstName: 'Fred',
lastName: 'Flintstone',
},
})
.then(function (response) {
console.log(response);
})
.catch(function (error) {
console.log(error);
});
可以向 daigo 传递相关配置来创建请求:
daigo({
method: 'POST',
url: '/user',
data: {
firstName: 'Fred',
lastName: 'Flintstone',
},
});
为了方便起见,已经为所有支持的请求方法提供了别名:
- daigo.request(config)
- daigo.get(url, [,config])
- daigo.post(url, [,config])
- daigo.delete(url, [,config])
- daigo.put(url, [,config])
- daigo.patch(url, [,config])
- daigo.options(url, [,config])
- daigo.head(url, [,config])
您可以使用自定义配置创建一个实例:
const instance = daigo.create({
baseURL: 'https://api.example.com',
timeout: 6000,
header: { 'X-Custom-Header': 'foobar' },
});
这些是创建请求时可用的配置项,并且完全兼容小程序请求配置:
{
// baseURL 将自动加在 url 前面,除非 url 是一个绝对 URL
baseURL: 'https://api.example.com',
// HTTP 请求方法,默认值为 GET
method: 'GET',
// 开发者服务器接口地址
url: '/user',
// 超时时间,单位为毫秒,默认值为 60000
timeout: 6000,
// 自定义请求头
header: { 'X-Custom-Header': 'foobar' },
// 请求的参数
data: {
firstName: 'Fred'
}
}
您可以指定默认配置,它将作用于每个请求:
daigo.defaults.baseURL = 'https://api.example.com';
daigo.defaults.timeout = 10000;
自定义实例默认值:
// 创建实例时配置默认值
const instance = daigo.create({
baseURL: 'https://api.example.com',
});
// 创建实例后修改默认值
instance.defaults.timeout = 10000;
配置会按照优先级进行合并,请求的配置参数优先级是最高的:
// 使用库提供的默认配置创建实例
const instance = daigo.create();
// 重写库的超时默认值
instance.defaults.timeout = 10000;
// 重写此请求的超时时间
instance.get('/query', {
timeout: 5000,
});
在请求或响应被 then 或 catch 处理前拦截它们:
// 添加请求拦截器
daigo.interceptors.request.use(
(config) => {
// 在发送请求之前做些什么
return config;
},
(error) => {
// 对请求错误做些什么
return Promise.reject(error);
}
);
// 添加响应拦截器
daigo.interceptors.response.use(
(response) => {
// 在响应数据做些什么
return response;
},
(error) => {
// 对响应错误做些什么
return Promise.reject(error);
}
);
如果你稍后需要移除拦截器,可以这样:
const interceptor = daigo.interceptors.request.use(function () {
/*...*/
});
daigo.interceptors.request.eject(interceptor);
您可以使用 CancelToken 取消一个请求:
const CancelToken = daigo.CancelToken;
const source = CancelToken.source();
daigo.get('/query', {
cancelToken: source.token,
});
// 取消请求 (message 参数是可选的)
source.cancel('Operation canceled by the user.');
您可以通过将 uploadFile 属性设置为 true 来上传一个文件。
daigo({
uploadFile: true,
url: 'https://example.weixin.qq.com/upload', // 仅为示例,非真实的接口地址
filePath: file.url,
name: 'file',
formData: { user: 'test' },
onProgressUpdate: (progress) => {
console.log(progress);
},
});
您可以通过将 downloadFile 属性设置为 true 来下载一个文件。
daigo({
downloadFile: true,
url: 'https://example.com/audio/123', // 仅为示例,非真实的接口地址
onProgressUpdate: (progress) => {
console.log(progress);
},
});