VUE提供了兩種路由模式:hash模式和history模式。其中,hash模式的路由路徑展現在URL的hash中,即“#”后面的部分;而history模式的路由路徑直接出現在URL中。
默認情況下,VUE采用hash模式,因為這種方式有以下優點:
1. 不需要服務器端配置,實現起來非常簡單。
2. 對于前端開發者來說,hash模式下改變URL不會導致頁面刷新,可以更好地實現單頁面應用。
不過,對于一些特殊需求,我們可能需要使用history模式。比如說,搜索引擎爬蟲無法抓取帶有hash的URL,這意味著使用hash模式會影響網站在搜索引擎中的排名。
要使用history模式,需要在VueRouter的實例中進行相應配置。可以在創建VueRouter實例時進行配置,也可以通過在實例上調用 router.mode() 方法改變路由模式。
// 創建VueRouter實例并指定使用history模式
const router = new VueRouter({
mode: 'history',
routes: [
// ...
]
})
如果想要更改路由模式,可以使用 router.mode() 方法來改變現有的路由模式。不過,在更改路由模式之前,要先確保路由已經被創建。
// 更改路由模式
router.mode('history')
注意,當使用history模式時,如果不對服務器進行配置,用戶在直接訪問路由路徑時會看到404錯誤。為了避免這種情況,需要在服務器上的處理程序中添加一個統配符,將所有的頁面都返回主頁。
// node.js中的Express路由處理程序
app.get('*', function(req, res) {
res.sendFile(__dirname + '/index.html')
})
最后,要記得在路由模式改變之后重新運行應用,或者使用router.replace()方法重新加載當前路由。
// 重新加載當前路由
router.replace(router.currentRoute.fullPath)