ホームページ >ウェブフロントエンド >jsチュートリアル >@rxliuli/vista の紹介: ミドルウェアをサポートする、Fetch と XHR の両方のための統合リクエスト インターセプター ライブラリ。
@rxliuli/vista は、Fetch/XHR リクエストの統合インターセプトをサポートする強力な同種リクエスト インターセプター ライブラリです。これにより、リクエストのライフサイクルのさまざまな段階に介入でき、リクエストの監視、変更、モック化などのさまざまな機能が有効になります。
npm install @rxliuli/vista # Or yarn add @rxliuli/vista # Or pnpm add @rxliuli/vista
import { Vista } from '@rxliuli/vista' new Vista() .use(async (c, next) => { console.log('Request started:', c.req.url) await next() }) .use(async (c, next) => { await next() console.log('Response data:', await c.res.clone().text()) }) .intercept()
new Vista() .use(async (c, next) => { c.req.headers.set('Authorization', 'Bearer token') await next() }) .intercept()
const cache = new Map() new Vista() .use(async (c, next) => { const key = c.req.url if (cache.has(key)) { c.res = cache.get(key).clone() return } await next() cache.set(key, c.res.clone()) }) .intercept()
new Vista() .use(async (c, next) => { const maxRetries = 3 let retries = 0 while (retries < maxRetries) { try { await next() break } catch (err) { retries++ if (retries === maxRetries) throw err } } }) .intercept()
new Vista() .use(async (c, next) => { await next() if (c.req.url === 'https://example.com/example') { const json = await c.res.json() json.id = 2 c.res = new Response(JSON.stringify(json), c.res) } }) .intercept()
次のメソッドを提供するメイン インターセプタ クラス:
ミドルウェア関数は 2 つのパラメーターを受け取ります:
const vista = new Vista() vista.intercept() // When not needed vista.destroy()
非同期操作をサポートしていますか?
はい、ミドルウェアは async/await 構文をサポートしています。
Node.js でのリクエストのインターセプトはサポートされていますか?
いいえ、ブラウザでのリクエストのインターセプトのみをサポートします。
問題やプルリクエストの送信を歓迎します!
MIT ライセンス
試してみて、その経験を教えてください。エラーや機能に関するフィードバックがあれば歓迎します。
以上が@rxliuli/vista の紹介: ミドルウェアをサポートする、Fetch と XHR の両方のための統合リクエスト インターセプター ライブラリ。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。