Skip to content

xdoer/PreQuest

Repository files navigation

PreQuest

一套模块化,可插拔的 JS 运行时 HTTP 请求解决方案。

npmMinzipped sizeNPM Downloadscode style: prettierCodacy BadgeGitHub license

简介

PreQuest 是一套 JS 运行时的 HTTP 解决方案。

它包含了一些针对不同 JS 运行平台的封装的请求库,并为这些请求库提供了一致的中间件、拦截器、全局配置等功能的体验

还针对诸如 Token 的添加,失效处理,无感知更新、接口缓存、错误重试等常见业务场景,提供了解决方案。

当这些功能不满足你的需求、或者你想定制化时,也可以基于 @prequest/core 快速封装一个实现你需求的请求库。

支持平台

Web、小程序、ReactNative、快应用等

使用示例

下面以 @prequest/xhr 为例,介绍使用方法

import{PreQuest,create}from'@prequest/xhr'importtimeoutMiddlewarefrom'@prequest/timeout'// 全局配置PreQuest.defaults.baseURL='http://locahost:8080'// 项目中如果有设置 header 的需求,建议先初始化有个空对象PreQuest.defaults.headers={}// 全局中间件PreQuest.use((ctx,next)=>{// 在这里,你可以全局修改请求参数console.log(ctx.request)awaitnext()// 这里,你可以全局修改响应数据console.log(ctx.response)})// 创建实例constprequest=create({headers: {'Content-Type': 'application/json; charset=utf-8',},})// 实例中间件prequest.use(timeoutMiddleware)// 请求调用prequest('/user')prequest('/user',{method: 'POST'})prequest.get('/user',{params: {a: 1}})prequest.post('/user',{data: {a: 1}})// 响应类型注入interfaceUser{}constuser=awaitprequest<User>('/user',{params: {id: 1}})constuser2=awaitprequest.get<User>('/user',{params: {id: 1}})

文档

website: https://pre-quest.vercel.app

贡献

Contributing Guide

License

MIT License

About

A Modular And Pluggable Solution For HTTP Request.

Topics

Resources

License

Contributing

Stars

Watchers

Forks

Contributors 2

  •  
  •  

Languages