feat: 添加queryclient
This commit is contained in:
parent
61a68fbd41
commit
742a562109
39
src/index.ts
39
src/index.ts
@ -1,5 +1,6 @@
|
|||||||
import { adapter } from './adapter.ts';
|
import { adapter } from './adapter.ts';
|
||||||
export { QueryWs } from './ws.ts';
|
import { QueryWs } from './ws.ts';
|
||||||
|
export { QueryOpts };
|
||||||
type Fn = (opts: {
|
type Fn = (opts: {
|
||||||
url?: string;
|
url?: string;
|
||||||
headers?: Record<string, string>;
|
headers?: Record<string, string>;
|
||||||
@ -37,6 +38,8 @@ type DataOpts = Partial<QueryOpts> & {
|
|||||||
* path: 'demo',
|
* path: 'demo',
|
||||||
* key: '1',
|
* key: '1',
|
||||||
* });
|
* });
|
||||||
|
*
|
||||||
|
* U是参数 V是返回值
|
||||||
*/
|
*/
|
||||||
export class Query<U = any, V = any> {
|
export class Query<U = any, V = any> {
|
||||||
adapter: typeof adapter;
|
adapter: typeof adapter;
|
||||||
@ -86,5 +89,39 @@ export class Query<U = any, V = any> {
|
|||||||
this.afterResponse = fn;
|
this.afterResponse = fn;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
/**
|
||||||
|
* 前端调用后端QueryRouter
|
||||||
|
*/
|
||||||
|
export class QueryClient<U = any, V = any> extends Query<U, V> {
|
||||||
|
tokenName: string;
|
||||||
|
storage: Storage;
|
||||||
|
token: string;
|
||||||
|
qws: QueryWs;
|
||||||
|
constructor(opts?: QueryOpts & { tokenName?: string; storage?: Storage }) {
|
||||||
|
super(opts);
|
||||||
|
this.tokenName = opts?.tokenName || 'token';
|
||||||
|
this.storage = opts?.storage || localStorage;
|
||||||
|
this.beforeRequest = async (opts) => {
|
||||||
|
const token = this.token || this.getToken();
|
||||||
|
if (token) {
|
||||||
|
opts.headers = {
|
||||||
|
...opts.headers,
|
||||||
|
Authorization: `Bearer ${token}`,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
return opts;
|
||||||
|
};
|
||||||
|
this.qws = new QueryWs({ url: opts?.url });
|
||||||
|
}
|
||||||
|
getToken() {
|
||||||
|
return this.storage.getItem(this.tokenName);
|
||||||
|
}
|
||||||
|
saveToken(token: string) {
|
||||||
|
this.storage.setItem(this.tokenName, token);
|
||||||
|
}
|
||||||
|
removeToken() {
|
||||||
|
this.storage.removeItem(this.tokenName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export { adapter };
|
export { adapter };
|
||||||
|
Loading…
x
Reference in New Issue
Block a user