Biblioteca de rede de miniprogramas, fornecendo
代码自动完成
completo e类型检查
, suportandoPromise
,重试
automática,缓存
,取消
,自定义超时
,自动暂停恢复
,拦截
global e事件监听
, etc.Redefina a API de rede do Wechat MiniProgram, incluindo
IntelliSense
completo eType Checking
, comPromise
,retry
,Cache
,CancelToken
,timeout
,ensureOnline
,interceptors
globais,event listeners
e muito mais.
onHeadersReceived
) e (evento onProgressUpdate
) transformSend
/ transformRresponse
interceptação de dados personalizados onSend
, onResponse
, onRejected
, onAbort
, onComplete
npm i miniprogram-network
compatível com es5
const Network = require ( 'miniprogram-network' ) ;
// 也可使用 es6 import 写法
// setConfig设置所有网络请求的全局默认配置,一次定义,所有文件中使用均生效
Network . setConfig ( 'baseURL' , 'https://miniprogram-network.newfuture.cc/' )
// 也可Network.REQUEST.Defaults,Network.DOWNLOAD.Defaults,Network.UPLOAD.Defaults 分别设置不同默认配置
Network . REQUEST . Defaults . transformResponse = Network . transformRequestResponseOkData
Network . get ( 'index.html' )
. then ( res => console . log ( res ) )
. finally ( ( ) => { console . info ( 'done' ) } ) //支持 finally操作
Network . patch ( 'items/{id}' , { dataKey : 'dataValue' } , {
params : { id : 123456 } , // 绑定模板参数
retry : 3 , // 重试3次
} ) . then ( ( item ) => console . log ( item ) )
Network . download ( 'network/' , 'lcoalpath' , {
onProgressUpdate : progressUpdateCallBack , //进度回调
transformResponse : Network . transformDownloadResponseOkData , //状态码2xx成功,返回本地路径
} ) . then ( path => console . log ( path ) )
. catch ( console . error )
Pronto para uso, sem necessidade de configuração adicional ou declaração de tipo
import { setConfig , REQUEST , download , transformRequestResponseOkData , transformDownloadResponseOkData , delayRetry } from 'miniprogram-network' ;
// setConfig设置所有网络请求的全局默认配置,一次定义,所有文件中使用均生效
setConfig ( 'baseURL' , 'https://miniprogram-network.newfuture.cc/' ) ;
// 也可通过 REQUEST.Defaults,DOWNLOAD.Defaults,UPLOAD.Defaults 分别设置不同默认配置
REQUEST . Defaults . transformResponse = transformRequestResponseOkData ;
// 请求发送失败时, 间隔1s再次重试,最多重试2次
REQUEST . Defaults . retry = delayRetry ( 1000 , 2 ) ;
REQUEST . get ( 'index.html' )
. then ( res => console . log ( res ) )
. finally ( ( ) => { console . info ( 'done' ) } ) ; //支持 finally操作
REQUEST . patch < Item > ( 'items/{id}' , { dataKey : 'dataValue' } , {
params : { id : 123456 } , // 绑定参数
retry : 3 , // 重试3次
} ) . then ( ( item : Item ) => console . log ( item ) ) ;
download < string > ( 'network/' , 'lcoalpath' , {
onProgressUpdate : ( res ) => console . log ( res ) , //进度回调
transformResponse : transformDownloadResponseOkData , //状态码2xx成功,返回本地路径
} ) . then ( ( path : string ) => console . log ( path ) )
. catch ( console . error ) ;
miniprogram-network
encapsula uniformemente as operações de rede. Para operações e uso detalhados, consulte o documento completo da rede de miniprogramas.
Contém definições de tipo completas, combinadas com o editor (VScode), etc., pode fornecer prompts de código completos e funções de preenchimento automático.
Fornece suporte genérico para TypeScript e pode realizar verificação completa de tipo estático.
Se você estiver preocupado com muitas dependências de pacotes, poderá usar miniprogram-build para empacotar o pequeno programa e agrupá-lo em um único arquivo.
Dicas: Desde miniprogram-network
>= 5.0.0, a camada inferior não usa mais miniprogram-queue
diretamente para encapsulamento de fila por padrão. Se necessário, você mesmo pode consultá-la ou usar a v4.x diretamente.
- wx.request suporta filas desde o miniaplicativo da biblioteca base 1.4.0 (2017.07)
- wx.downloadFile suporta filas desde o miniaplicativo da biblioteca base 1.4.0 (2017.07)
- wx.uploadFile suporta filas desde o miniaplicativo da biblioteca base 2.4.1 (2018.11)
Request
de miniprogram-request
Upload
do miniprogram-uploader
Download
do miniprogram-downloader
abort
)