useRequestFetch
使用 useRequestFetch 組合式函式,轉發伺服器端 fetch 請求的請求上下文和標頭。
您可以使用 useRequestFetch
在發出伺服器端 fetch 請求時轉發請求上下文和標頭。
當發出客戶端 fetch 請求時,瀏覽器會自動發送必要的標頭。但是,在伺服器端渲染期間發出請求時,由於安全考量,我們需要手動轉發標頭。
不打算轉發的標頭將不會包含在請求中。這些標頭包括,例如:
transfer-encoding
、connection
、keep-alive
、upgrade
、expect
、host
、accept
useFetch
組合式函式在底層使用 useRequestFetch
自動轉發請求上下文和標頭。<script setup lang="ts">
// This will forward the user's headers to the `/api/cookies` event handler
// Result: { cookies: { foo: 'bar' } }
const requestFetch = useRequestFetch()
const { data: forwarded } = await useAsyncData(() => requestFetch('/api/cookies'))
// This will NOT forward anything
// Result: { cookies: {} }
const { data: notForwarded } = await useAsyncData(() => $fetch('/api/cookies'))
</script>
在客戶端導航期間的瀏覽器中,
useRequestFetch
的行為將與常規 $fetch
完全相同。