溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Vue在 Nuxt.js中如何重定向404頁(yè)面

發(fā)布時(shí)間:2021-08-18 09:48:54 來(lái)源:億速云 閱讀:298 作者:小新 欄目:web開(kāi)發(fā)

小編給大家分享一下Vue在 Nuxt.js中如何重定向404頁(yè)面,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

Nuxt.js 依據(jù) pages 目錄結(jié)構(gòu)自動(dòng)生成 vue-router 模塊的路由配置。

要在頁(yè)面之間使用路由,我們建議使用<nuxt-link> 標(biāo)簽。

正文

對(duì)我來(lái)說(shuō),Nuxt 是我所用過(guò)最好用的軟件代碼之一。它可以讓我高效率地打造網(wǎng)站應(yīng)用,無(wú)論這些應(yīng)用是 SPA,還是 SSR,又或者是靜態(tài)站點(diǎn),這同時(shí)也是 JAM Stack 上面所提到的趨勢(shì)。

順便提一點(diǎn),我們這個(gè)網(wǎng)站Vuedose 也是使用 Nuxt 所建立靜態(tài)站點(diǎn)。

但是,絕大多數(shù)自己領(lǐng)悟的很有意思的使用技巧并沒(méi)有被記載沉淀下來(lái),這不行,現(xiàn)在我們就來(lái)分享第一個(gè) Nuxt 的技巧。

如果你熟悉 Nuxt.js,那么你就應(yīng)該知道pages 的概念是什么。同樣地,你也應(yīng)該知道這個(gè)特殊的Error Page,雖然它是被放在 Layouts 文件夾中的,但它是被作為一個(gè) page。

你可以去重寫(xiě)這個(gè)默認(rèn)的錯(cuò)誤頁(yè),并且根據(jù)你的需求去定制它,但是如果我們想要一個(gè)不同的表現(xiàn)形式呢?

在一些情況下,比如當(dāng)用戶訪問(wèn)一個(gè)并不存在的頁(yè)面時(shí),我們想要將其重定向到網(wǎng)站主頁(yè)。

這里有個(gè)方法:你可以通過(guò)簡(jiǎn)單地創(chuàng)建 pages/*.vue 組件來(lái)完成這個(gè)需求:

<!-- pages/*.vue -->
<script>
export default {
 asyncData ({ redirect }) {
  return redirect('/')
 }
}
</script>

在 Nuxt 中,路由是通過(guò)文件命名來(lái)定義的。所以當(dāng)我們創(chuàng)建了一個(gè) *.vue 文件是,我們實(shí)際上是在 Vue Router 上使用通配符的路由。

然后,我們使用 Nuxt 上下文中的 rediect 方法來(lái)實(shí)現(xiàn)重定向,無(wú)論它是在客戶端還是在服務(wù)器端。

我們?cè)?asyncData 方法中去做這個(gè)重定向,是因?yàn)槲覀冊(cè)谀抢镉猩舷挛摹5?,我們也可以?fetch 方法中達(dá)到同樣的效果:

<!-- pages/*.vue -->
<script>
export default {
 fetch ({ redirect }) {
  return redirect('/')
 }
}
</script>

快去使用一下吧,嘗試訪問(wèn)任何一個(gè)不存在 url,你應(yīng)該能看到它是如何被重定向的。

以上是“Vue在 Nuxt.js中如何重定向404頁(yè)面”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI