透過 100+ 個秘訣學習 Nuxt!

useRequestFetch

使用 useRequestFetch 組合式函式,轉發伺服器端 fetch 請求的請求上下文和標頭。

您可以使用 useRequestFetch 在發出伺服器端 fetch 請求時轉發請求上下文和標頭。

當發出客戶端 fetch 請求時,瀏覽器會自動發送必要的標頭。但是,在伺服器端渲染期間發出請求時,由於安全考量,我們需要手動轉發標頭。

不打算轉發的標頭將不會包含在請求中。這些標頭包括,例如:transfer-encodingconnectionkeep-aliveupgradeexpecthostaccept
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 完全相同。