Vue在 Nuxt.js 中重定向 404 頁面的方法
Nuxt.js 依據(jù) pages 目錄結(jié)構(gòu)自動生成 vue-router 模塊的路由配置。
要在頁面之間使用路由,我們建議使用<nuxt-link>
標(biāo)簽。
正文
對我來說,Nuxt 是我所用過最好用的軟件代碼之一。它可以讓我高效率地打造網(wǎng)站應(yīng)用,無論這些應(yīng)用是 SPA,還是 SSR,又或者是靜態(tài)站點,這同時也是 JAM Stack 上面所提到的趨勢。
順便提一點,我們這個網(wǎng)站Vuedose 也是使用 Nuxt 所建立靜態(tài)站點。
但是,絕大多數(shù)自己領(lǐng)悟的很有意思的使用技巧并沒有被記載沉淀下來,這不行,現(xiàn)在我們就來分享第一個 Nuxt 的技巧。
如果你熟悉 Nuxt.js,那么你就應(yīng)該知道pages 的概念是什么。同樣地,你也應(yīng)該知道這個特殊的Error Page,雖然它是被放在 Layouts 文件夾中的,但它是被作為一個 page。
你可以去重寫這個默認(rèn)的錯誤頁,并且根據(jù)你的需求去定制它,但是如果我們想要一個不同的表現(xiàn)形式呢?
在一些情況下,比如當(dāng)用戶訪問一個并不存在的頁面時,我們想要將其重定向到網(wǎng)站主頁。
這里有個方法:你可以通過簡單地創(chuàng)建 pages/*.vue
組件來完成這個需求:
<!-- pages/*.vue --> <script> export default { asyncData ({ redirect }) { return redirect('/') } } </script>
在 Nuxt 中,路由是通過文件命名來定義的。所以當(dāng)我們創(chuàng)建了一個 *.vue
文件是,我們實際上是在 Vue Router
上使用通配符的路由。
然后,我們使用 Nuxt 上下文中的 rediect
方法來實現(xiàn)重定向,無論它是在客戶端還是在服務(wù)器端。
我們在 asyncData 方法中去做這個重定向,是因為我們在那里有上下文。但是,我們也可以在 fetch 方法中達(dá)到同樣的效果:
<!-- pages/*.vue --> <script> export default { fetch ({ redirect }) { return redirect('/') } } </script>
快去使用一下吧,嘗試訪問任何一個不存在 url,你應(yīng)該能看到它是如何被重定向的。
總結(jié)
以上所述是小編給大家介紹的Vue在 Nuxt.js 中重定向 404 頁面的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
- SpringBoot+jsp項目啟動出現(xiàn)404的解決方法
- vue.js vue-router如何實現(xiàn)無效路由(404)的友好提示
- nodejs發(fā)送http請求時遇到404長時間未響應(yīng)的解決方法
- 使用nodejs中httpProxy代理時候出現(xiàn)404異常的解決方法
- 解決js圖片加載時出現(xiàn)404的問題
- NodeJS Express框架中處理404頁面一個方式
- jsp提交到Servlet報404錯誤問題解決(webroot下子目錄)
- asp+javascript實現(xiàn)404頁的處理轉(zhuǎn)換
- JS出現(xiàn)404錯誤原理及解決方案
相關(guān)文章
Vuex,iView UI面包屑導(dǎo)航使用擴(kuò)展詳解
今天小編就為大家分享一篇Vuex,iView UI面包屑導(dǎo)航使用擴(kuò)展詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11vue項目使用axios發(fā)送請求讓ajax請求頭部攜帶cookie的方法
今天小編就為大家分享一篇vue項目使用axios發(fā)送請求讓ajax請求頭部攜帶cookie的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09Vue3響應(yīng)式對象是如何實現(xiàn)的(1)
這篇文章主要介紹了Vue3響應(yīng)式對象是如何實現(xiàn)的,文章圍繞主題展開詳細(xì)的內(nèi)容介紹具有一定的參考價值,需要的小伙伴可以參考一下2022-08-08解決vue2.x中數(shù)據(jù)渲染以及vuex緩存的問題
本篇文章主要介紹了vue2.x中請求之前數(shù)據(jù)顯示以及vuex緩存的問題,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07