Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lei1248276/simple-axios-wechat
简易的axios微信小程序版使用typescript实现
https://github.com/lei1248276/simple-axios-wechat
axios http miniprogram promise request typescript wechat weixin
Last synced: about 2 months ago
JSON representation
简易的axios微信小程序版使用typescript实现
- Host: GitHub
- URL: https://github.com/lei1248276/simple-axios-wechat
- Owner: lei1248276
- License: mit
- Created: 2023-03-04T10:20:16.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-04-27T06:44:05.000Z (over 1 year ago)
- Last Synced: 2024-11-07T21:04:10.290Z (2 months ago)
- Topics: axios, http, miniprogram, promise, request, typescript, wechat, weixin
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/simple-axios-wechat
- Size: 289 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# simple-axios-wechat
- 小于1kb的简易的axios微信小程序版使用typescript实现## 目录
- [安装](#Installing)
- [调用](#直接调用)
- [method 别名](#method别名)
- [Example](#Example)
- [get请求并定义返回数据类型](#get请求并定义返回数据类型)
- [post请求并定义返回数据类型](#post请求并定义返回数据类型)
- [全局默认值](#全局默认值)
- [创建实例](#创建实例)
- [拦截器](#拦截器)
- [获取RequestTask(中断请求、监听 HTTP)](#获取RequestTask)
- [自定义请求方法](#自定义请求方法)## Installing
### Package manager
Using npm:
```bash
$ npm install simple-axios-wechat
```Using yarn:
```bash
$ yarn add simple-axios-wechat
```### 直接调用
- (SimpleAxios([config](https://developers.weixin.qq.com/miniprogram/dev/api/network/request/wx.request.html)))
```ts
import SimpleAxios from 'simple-axios-wechat'SimpleAxios<{result: any}>(config)
.then(res => { console.log(res) })
.catch(err => { console.error(err) })
```### method别名
- 与SimpleAxios.create()实例一致
##### axios.request<{result: any}>(config)
##### axios.get<{result: any}>(url[, config])
##### axios.post<{result: any}>(url[, data[, config]])
##### axios.put<{result: any}>(url[, data[, config]])
##### axios.delete<{result: any}>(url[, config])
##### axios.head<{result: any}>(url[, config])
##### axios.options<{result: any}>(url[, config])
##### axios.trace<{result: any}>(url[, data[, config]])
##### axios.connect<{result: any}>(url[, data[, config]])## Example
### get请求并定义返回数据类型
```ts
import SimpleAxios from 'simple-axios-wechat'
// 默认 get 请求
SimpleAxios<{result: string}>({ url: 'http://example.org/get' })
.then(res => { console.log(res) })
.catch(err => { console.error(err) })SimpleAxios.get<{result: string}>('http://example.org/get')
.then(res => { console.log(res) })
.catch(err => { console.error(err) })
```### post请求并定义返回数据类型
```js
SimpleAxios<{result: string}>({ url: 'http://example.org/get', method: 'POST' })
.then(res => { console.log(res) })
.catch(err => { console.error(err) })SimpleAxios.post<{result: string}>('http://example.org/post', { data: {} })
.then((res) => { console.log(res) })
.catch((err) => { console.error(err) });
```### 全局默认值
- (默认值优先级与axios一致,后设置大于先设置)
```ts
import SimpleAxios from 'simple-axios-wechat'SimpleAxios.defaults.baseURL = 'http://example.org/get'
SimpleAxios.defaults.timeout = 10 * 1000
```### 创建实例
```ts
import SimpleAxios from 'simple-axios-wechat'const simpleAxios = SimpleAxios.create({
baseURL: 'http://example.org/get',
timeout: 10 * 1000
})
```### 拦截器
```ts
import SimpleAxios from 'simple-axios-wechat'const simpleAxios = SimpleAxios.create({
baseURL: 'http://example.org/get'
})simpleAxios.interceptors.request.use((config) => {
// 干点啥?
return config
}, (err) => {
return Promise.reject(err)
})simpleAxios.interceptors.response.use((response) => {
// 总得干点啥吧?
return response
}, (err) => {
return Promise.reject(err)
})
```### 获取RequestTask
- 在请求config配置项中通过回调获取[RequestTask](https://developers.weixin.qq.com/miniprogram/dev/api/network/request/RequestTask.html)(比如用来 abort())
```ts
import SimpleAxios from 'simple-axios-wechat'SimpleAxios<{data: any, state: number}>({
url: 'http://example.org/get',
getRequestTask: (task) => { task.abort() }
})
.catch(err => { console.error(err) })
```### 自定义请求方法
- (要求返回一个Promise)
```ts
import SimpleAxios from 'simple-axios-wechat'const simpleAxios = SimpleAxios.create({
baseURL: 'http://example.org/get',
adapter: function adapter(config) {
return new Promise((resolve, reject) => {
const RequestTask = wx.request({
...config,
success: (res) => { resolve(res) },
fail: (err) => { reject(err) }
})
// ! ** 自定义adapter需要通过回调暴露RequestTask **
config.getRequestTask && config.getRequestTask(RequestTask)
})
}
})
```