溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

hash模式與history模式在Vue-router項目中有什么不同

發(fā)布時間:2020-12-15 17:31:52 來源:億速云 閱讀:192 作者:Leah 欄目:開發(fā)技術(shù)

本篇文章為大家展示了hash模式與history模式在Vue-router項目中有什么不同,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

VUE路由的hash模式與history模式的區(qū)別,這個也是面試常問的問題,這個題其實就是考驗你的開發(fā)經(jīng)驗是否屬實。

小白回答:hash模式url帶#號,history模式不帶#號。

大牛解答:

形式上:hash模式url里面永遠帶著#號,開發(fā)當中默認使用這個模式。如果用戶考慮url的規(guī)范那么就需要使用history模式,因為history模式?jīng)]有#號,是個正常的url,適合推廣宣傳;

功能上:比如我們在開發(fā)app的時候有分享頁面,那么這個分享出去的頁面就是用vue或是react做的,咱們把這個頁面分享到第三方的app里,有的app里面url是不允許帶有#號的,所以要將#號去除那么就要使用history模式,但是使用history模式還有一個問題就是,在訪問二級頁面的時候,做刷新操作,會出現(xiàn)404錯誤,那么就需要和后端人配合,讓他配置一下apache或是nginx的url重定向,重定向到你的首頁路由上就ok了

正題開始

為了達到改變視圖的同時不會向后端發(fā)出請求這一目的,瀏覽器當前提供了以下兩種支持:

hash模式:即地址欄 URL 中的 # 符號

比如這個 URL:http://www.abc.com/#/hello, hash 的值為 #/hello

它的特點在于:hash 雖然出現(xiàn)在 URL 中,但不會被包括在 HTTP 請求中,對后端完全沒有影響,因此改變 hash 不會重新加載頁面。

history模式:利用了 HTML5 History Interface 中新增的 pushState() 和 replaceState() 方法。(需要特定瀏覽器支持)

這兩個方法應用于瀏覽器的歷史記錄棧,在當前已有的 back()、forward()、go() 方法的基礎之上,這兩個方法提供了對歷史記錄進行修改的功能。當這兩個方法執(zhí)行修改時,只能改變當前地址欄的 URL,但瀏覽器不會向后端發(fā)送請求,也不會觸發(fā)popstate事件的執(zhí)行

因此可以說,hash 模式和 history 模式都屬于瀏覽器自身的特性,Vue-Router 只是利用了這兩個特性(通過調(diào)用瀏覽器提供的接口)來實現(xiàn)前端路由.

vue中的router有兩種模式:hash模式(默認)、history模式(需配置mode: 'history')

hash模式與history模式在Vue-router項目中有什么不同

vue中的hash模式

即地址欄 URL 中的 # 符號,這個#就是hash符號,中文名哈希符或錨點

比如這個 URL:http://www.baidu.com/#/home,hash 的值為 #/home

它的特點在于:hash 雖然出現(xiàn)在 URL 中,但不會被包括在 HTTP 請求中,對后端完全沒有影響,因此改變 hash 不會重新加載頁面。

hash模式與history模式在Vue-router項目中有什么不同

路由的哈希模式其實是利用了window.onhashchange事件,也就是說你的url中的哈希值(#后面的值)如果有變化,就會自動調(diào)用hashchange的監(jiān)聽事件,在hashchange的監(jiān)聽事件內(nèi)可以得到改變后的url,這樣能夠找到對應頁面進行加載

window.addEventListener('hashchange', () => {
  // 把改變后的url地址欄的url賦值給data的響應式數(shù)據(jù)current,調(diào)用router-view去加載對應的頁面
  this.data.current = window.location.hash.substr(1)
})

vue中history模式

HTML5 History Interface 中新增的兩個神器 pushState() 和 replaceState() 方法(需要特定瀏覽器支持),用來完成 URL 跳轉(zhuǎn)而無須重新加載頁面,不過這種模式還需要后臺配置支持。因為我們的應用是個單頁客戶端應用,如果后臺沒有正確的配置,就需要前端自己配置404頁面。

hash模式與history模式在Vue-router項目中有什么不同

pushState() 和 replaceState() 這兩個神器的作用就是可以將url替換并且不刷新頁面,好比掛羊頭賣狗肉,http并沒有去請求服務器該路徑下的資源,一旦刷新就會暴露這個實際不存在的“羊頭”,顯示404(因為瀏覽器一旦刷新,就是去真正請求服務器資源)

那么如何去解決history模式下刷新報404的弊端呢,這就需要服務器端做點手腳,將不存在的路徑請求重定向到入口文件(index.html),前后端聯(lián)手,齊心協(xié)力做好“掛羊頭賣狗肉”的完美特效

pushState方法、replaceState方法,只能導致history對象發(fā)生變化,從而改變當前地址欄的 URL,但瀏覽器不會向后端發(fā)送請求,也不會觸發(fā)popstate事件的執(zhí)行

popstate事件的執(zhí)行是在點擊瀏覽器的前進后退按鈕的時候,才會被觸發(fā)

window.addEventListener('popstate', () => {
 this.data.current = window.location.pathname
})

使用場景

一般場景下,hash 和 history 都可以,除非你更在意顏值,# 符號夾雜在 URL 里看起來確實有些不太美麗。

如果不想要很丑的 hash,我們可以用路由的 history 模式,這種模式充分利用 history.pushState API 來完成URL 跳轉(zhuǎn)而無須重新加載頁面。 Vue-router 另外,根據(jù) Mozilla Develop Network 的介紹,調(diào)用 history.pushState() 相比于直接修改 hash,存在以下優(yōu)勢:

pushState() 設置的新 URL 可以是與當前 URL 同源的任意 URL;而 hash 只可修改 # 后面的部分,因此只能設置與當前 URL 同文檔的 URL

pushState() 設置的新 URL 可以與當前 URL 一模一樣,這樣也會把記錄添加到棧中;而 hash 設置的新值必須與原來不一樣才會觸發(fā)動作將記錄添加到棧中

pushState() 通過 stateObject 參數(shù)可以添加任意類型的數(shù)據(jù)到記錄中;而 hash 只可添加短字符串

pushState() 可額外設置 title 屬性供后續(xù)使用

上述內(nèi)容就是hash模式與history模式在Vue-router項目中有什么不同,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

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

AI