-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathfetch.ts
120 lines (111 loc) · 3.21 KB
/
fetch.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
import { WxQueue } from "miniprogram-queue";
/// <reference types="dom">
//@ts-ignore
const RequestMQ = new WxQueue(wx.request);
/**
* fetch 封装
* @see https://developer.mozilla.org/zh-CN/docs/Web/API/Fetch_API
* @param url 请求URL或者Request对象
* @param init 请求参数
*/
export function fetch(url: RequestInfo, init?: RequestInit): Promise<Response> {
init = init || {}
const param: any = ((typeof url) !== 'object') ?
{
url,
data: init.body,
header: init.headers || {},
method: init.method,
dataType: 'text'
} : {
url: (url as Request).url,
data: (url as Request).json() || (url as Request).text() || (url as Request).body,
method: init.method || (url as Request).method,
header: Object.assign({}, (url as Request).headers, init.headers),
dataType: 'text',
};
return new Promise<Response>((resolve, reject) => {
param.success = function (res: any) {
var response = new wxHttpResponse(res);
resolve(response);
};
param.fail = reject;
param.complete = init['complete'];
RequestMQ.push(param);
})
}
class wxHttpResponse implements Response {
headers: Headers;
ok: boolean;
redirected: boolean;
status: number;
statusText: string;
trailer: Promise<Headers>;
type: ResponseType;
url: string;
body: ReadableStream | any;
bodyUsed: boolean;
constructor(res: { data: any, statusCode: number, header: Headers }) {
this.status = res.statusCode;
this.headers = res.header;
this.body = res.data;
this.ok = res.statusCode >= 200 && res.statusCode < 300;
this.bodyUsed = false
}
/**
* Copy
*/
clone(): Response {
return Object.assign(this);
}
arrayBuffer(): Promise<ArrayBuffer> {
throw new Error("Method not implemented.");
}
blob(): Promise<Blob> {
throw new Error("Method not implemented.");
}
formData(): Promise<FormData> {
return new Promise((resolve, reject) => {
let data = this.body;
try {
if (typeof data === "string") {
data = JSON.parse(data);
}
const formData = new FormData();
for (let key in data) {
formData.append(key, data[key]);
}
resolve(formData);
this.bodyUsed = true;
} catch (error) {
reject(error);
}
});
}
/**
* to json as promise
*/
json(): Promise<any> {
return new Promise((resolve, reject) => {
try {
resolve(JSON.parse(this.body));
this.bodyUsed = true;
} catch (error) {
reject(error);
}
})
}
/**
* to string as promise
*/
text(): Promise<string> {
return new Promise((resolve, reject) => {
try {
resolve(this.body);
this.bodyUsed = true;
} catch (error) {
reject(error);
}
})
}
}