Nuxt3項(xiàng)目中問(wèn)題匯總之刷新頁(yè)面useFetch無(wú)返回解決
坑有千千萬(wàn),匯總下目前的解決辦法,也因?yàn)閷?duì)框架的不夠深入,掌握得有限,大家有更好的,請(qǐng)指教【抱拳】
瀏覽器刷新的時(shí)候頁(yè)面沒(méi)有顯示數(shù)據(jù),接口data無(wú)返回。本身nuxt的useFetch在參數(shù)不變的情況下,數(shù)據(jù)是不會(huì)重新從后臺(tái)接口去請(qǐng)求數(shù)據(jù)的,會(huì)直接拿上一次的結(jié)果。但是有實(shí)時(shí)去后臺(tái)獲取數(shù)據(jù)這樣的需求,比如我的關(guān)注頁(yè)面,在其他頁(yè)面點(diǎn)了關(guān)注,每次進(jìn)這個(gè)頁(yè)面或者刷新都需要去后臺(tái)重新獲取數(shù)據(jù),所以我給入?yún)⒓恿艘粋€(gè)以時(shí)間戳為值的參數(shù)key,但是這樣導(dǎo)致每次F5刷新頁(yè)面的時(shí)候,都拿不到數(shù)據(jù),導(dǎo)致頁(yè)面沒(méi)有顯示。Suspense不起作用。
const { data } = await useFetch(
'http://www.baidu.com/xx-list',
{
method: 'get',
key: uuid(),
headers: {
Authorization: 'xxx'
},
params: {
page: currentPage.value,
size: 10
}
}
)
console.log('data', data)
刷新的時(shí)候打印結(jié)果data.value是null

解決1: 加個(gè)定時(shí)器(不友好)
<script lang="ts" setup>
const { data } = await useFetch(
'http://www.baidu.com/xx-list',
{
method: 'get',
key: uuid(),
headers: {
Authorization: 'xxxx'
},
params: {
page: currentPage.value,
size: 10
}
}
)
setTimeout(() => {
console.log('data', data)
}, 500);
</script>
解決2: 函數(shù)方法+await nextTick(),把獲取數(shù)據(jù)接口放在方法里,方法里使用await nextTick(),然后調(diào)用方法
<script lang="ts" setup>
import { nextTick } from 'vue'
const feachData = async (key = '') => {
await nextTick()
const { data, pending, error, refresh } = await useFetch(
'http://www.baidu.com/xx-list',
{
method: 'get',
key: uuid(),
headers: {
Authorization: 'xxx'
},
params: {
page: currentPage.value,
size: 10
}
}
)
console.log('data', data.value)
}
feachData()
<script>總結(jié)
到此這篇關(guān)于Nuxt3項(xiàng)目中刷新頁(yè)面useFetch無(wú)返回解決辦法的文章就介紹到這了,更多相關(guān)Nuxt3刷新頁(yè)面useFetch無(wú)返回內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
單頁(yè)面Vue頁(yè)面刷新出現(xiàn)閃爍問(wèn)題及解決
這篇文章主要介紹了單頁(yè)面Vue頁(yè)面刷新出現(xiàn)閃爍問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
Vuex狀態(tài)機(jī)的快速了解與實(shí)例應(yīng)用
Vuex是專(zhuān)門(mén)為Vuejs應(yīng)用程序設(shè)計(jì)的狀態(tài)管理工具,這篇文章主要給大家介紹了關(guān)于Vuex狀態(tài)機(jī)快速了解與實(shí)例應(yīng)用的相關(guān)資料,需要的朋友可以參考下2021-06-06
vue-meta實(shí)現(xiàn)router動(dòng)態(tài)設(shè)置meta標(biāo)簽的方法
這篇文章主要介紹了vue-meta實(shí)現(xiàn)router動(dòng)態(tài)設(shè)置meta標(biāo)簽,實(shí)現(xiàn)思路非常簡(jiǎn)單內(nèi)容包括mata標(biāo)簽的特點(diǎn)和mata標(biāo)簽共有兩個(gè)屬性,分別是http-equiv屬性和name屬性,本文通過(guò)實(shí)例代碼給大家詳細(xì)講解需要的朋友可以參考下2022-11-11
vue2 拖動(dòng)排序 vuedraggable組件的實(shí)現(xiàn)
這篇文章主要介紹了vue2 拖動(dòng)排序 vuedraggable組件的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
Vue項(xiàng)目中ESLint配置超全指南(VScode)
ESLint是一個(gè)代碼檢查工具,用來(lái)檢查你的代碼是否符合指定的規(guī)范,下面這篇文章主要給大家介紹了關(guān)于Vue項(xiàng)目中ESLint配置(VScode)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-04-04
如何通過(guò)Vue自帶服務(wù)器實(shí)現(xiàn)Ajax請(qǐng)求跨域(vue-cli)
從A頁(yè)面訪問(wèn)到B頁(yè)面,并且要獲取到B頁(yè)面上的數(shù)據(jù),而兩個(gè)頁(yè)面所在的端口、協(xié)議和域名中哪怕有一個(gè)不對(duì)等,那么這種行為就叫跨域,這篇文章給大家介紹如何通過(guò)Vue自帶服務(wù)器實(shí)現(xiàn)Ajax請(qǐng)求跨域(vue-cli),感興趣的朋友一起看看吧2023-10-10

