欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

區(qū)分vue-router的hash和history模式

 更新時間:2020年10月03日 10:03:32   作者:guo&qi  
這篇文章主要介紹了區(qū)分vue-router的hash和history模式,幫助大家更好的理解和學習vue路由,感興趣的朋友可以了解下

一、概念

  為了構(gòu)建 SPA(單頁面應(yīng)用),需要引入前端路由系統(tǒng),這也就是 Vue-Router 存在的意義。

  前端路由的核心,就在于:改變視圖的同時不會向后端發(fā)出請求。

  為了達到這種目的,瀏覽器當前提供了以下兩種支持:

  1.hash——即地址欄 URL 中的 # 符號(此 hash 不是密碼學里的散列運算)。

   比如這個 URL:http://www.abc.com/#/hello,hash 的值為 #/hello。
   它的特點在于:hash 雖然出現(xiàn)在 URL 中,但不會被包括在 HTTP 請求中,對后端完全沒有影響,因此改變 hash 不會重新加載頁面。

  2.history —— 利用了 HTML5 History Interface 中新增的 pushState() 和 replaceState() 方法。

   這兩個方法應(yīng)用于瀏覽器的歷史記錄棧,在當前已有的 back、forward、go 的基礎(chǔ)之上,它們提供了對歷史記錄進行修改的功能。
   只是當它們執(zhí)行修改時,雖然改變了當前的 URL,但瀏覽器不會立即向后端發(fā)送請求。

二、hash模式

  hash模式背后的原理是onhashchange事件,可以在window對象上監(jiān)聽這個事件:

window.onhashchange = function(event){
 console.log(event.oldURL, event.newURL);
 let hash = location.hash.slice(1);
 document.body.style.color = hash;
}

  這段可以在hash改變的時候改變字體顏色。

  hash發(fā)生變化的url都會被瀏覽器記錄下來,從而你會發(fā)現(xiàn)瀏覽器的前進后退都可以使用了,同時點擊后退時,頁面字體顏色也會發(fā)生變化。

  這樣一來雖然沒有向后端發(fā)送請求,但是頁面狀態(tài)和url關(guān)聯(lián)在了一起,這就是前端路由。

三、history模式

  隨著history api的到來,前端路由開始進化了,前面的onhashchange,你只能改變#后面的url片段,而history api則給了前端完全的自由。

  history api可以分為兩大部分,切換和修改。

  切換歷史狀態(tài)包括back、forward、go三個方法,對應(yīng)瀏覽器的前進,后退,跳轉(zhuǎn)操作。

  修改歷史狀態(tài)包括了pushState、replaceState兩個方法,這兩個方法接收三個參數(shù):stateObj,title,url

history.pushState({color:'red'}, 'red', 'red')
history.back();
setTimeout(function(){
 history.forward();
 },0)
window.onpopstate = function(event){
  console.log(event.state)
  if(event.state && event.state.color === 'red'){
   document.body.style.color = 'red';
  }
}

  通過pushstate把頁面的狀態(tài)保存在state對象中,當頁面的url再變回這個url時,可以通過event.state取到這個state對象,從而可以對頁面狀態(tài)進行還原,這里的頁面狀態(tài)就是頁面字體顏色。

  其實滾動條的位置,閱讀進度,組件的開關(guān)的這些頁面狀態(tài)都可以存儲到state的里面。

四、history模式的問題

  通過history api,我們丟掉了丑陋的#,但是它也有個問題:不怕前進,不怕后退,就怕刷新,f5,(如果后端沒有準備的話),因為刷新是實實在在地去請求服務(wù)器的。

  在hash模式下,前端路由修改的是#中的信息,而瀏覽器請求時是不帶它的,所以沒有問題。但是在history下,你可以自由的修改path,當刷新時,如果服務(wù)器中沒有相應(yīng)的響應(yīng)或者資源,會刷出一個404來。

  所以呢,你要在服務(wù)端增加一個覆蓋所有情況的候選資源:如果 URL 匹配不到任何靜態(tài)資源,則應(yīng)該返回同一個 index.html 頁面,這個頁面就是你 app 依賴的頁面。

  如果使用nginx,后端配置如下:

location / {
 try_files $uri $uri/ /index.html;
}

以上就是區(qū)分vue-router的hash和history模式的詳細內(nèi)容,更多關(guān)于vue-router hash和history模式的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解Vue的computed(計算屬性)使用實例之TodoList

    詳解Vue的computed(計算屬性)使用實例之TodoList

    本篇文章主要介紹了詳解Vue的computed(計算屬性)使用實例之TodoList,具有一定的參考價值,有興趣的可以了解一下
    2017-08-08
  • vue3?setup語法糖各種語法新特性的使用方法(vue3+vite+pinia)

    vue3?setup語法糖各種語法新特性的使用方法(vue3+vite+pinia)

    這篇文章主要介紹了vue3?setup語法糖各種語法新特性的使用(vue3+vite+pinia),本文主要是記錄vue3的setup語法糖的各種新語法的使用方法,需要的朋友可以參考下
    2022-09-09
  • vue圖片拖拉轉(zhuǎn)放大縮小組件使用詳解

    vue圖片拖拉轉(zhuǎn)放大縮小組件使用詳解

    這篇文章主要為大家詳細介紹了vue圖片拖拉轉(zhuǎn)放大縮小組件的使用,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • Vue實現(xiàn)Excel預(yù)覽功能使用場景示例詳解

    Vue實現(xiàn)Excel預(yù)覽功能使用場景示例詳解

    這篇文章主要為大家介紹了Vue實現(xiàn)Excel預(yù)覽功能使用場景示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09
  • vue-resource 攔截器(interceptor)的使用詳解

    vue-resource 攔截器(interceptor)的使用詳解

    本篇文章主要介紹了vue-resource 攔截器(interceptor)的使用詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • 圖文詳解Element-UI中自定義修改el-table樣式

    圖文詳解Element-UI中自定義修改el-table樣式

    elementUI提供的組件間距、樣式都比較大,如果直接套用,在頁面顯示可能就會顯得很大,就比如表格,表頭、行寬如果不修改的話,遇到列較多的時候,會顯得整個頁面就不好看,下面這篇文章主要給大家介紹了關(guān)于Element-UI中自定義修改el-table樣式的相關(guān)資料,需要的朋友可以參考下
    2022-08-08
  • Vue通過echarts實現(xiàn)數(shù)據(jù)圖表化顯示

    Vue通過echarts實現(xiàn)數(shù)據(jù)圖表化顯示

    Echarts,它是一個與框架無關(guān)的 JS 圖表庫,但是它基于Js,這樣很多框架都能使用它,例如Vue,估計IONIC也能用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • 詳解vue高級特性

    詳解vue高級特性

    這篇文章主要介紹了vue高級特性的相關(guān)知識,文中介紹非常細致,幫助大家更好的參考和學習,感興趣的朋友可以了解下
    2020-06-06
  • Vue from-validate 表單驗證的示例代碼

    Vue from-validate 表單驗證的示例代碼

    本篇文章主要介紹了Vue from-validate 表單驗證的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • vue封裝axios的兩種方法總結(jié)

    vue封裝axios的兩種方法總結(jié)

    在不同的前端項目中使用相同的axios封裝有利于保持一致性,有利于數(shù)據(jù)之間的傳遞和處理,本文主要提供兩種對axios進行封裝的思路,有需要的小伙伴可以參考一下
    2023-10-10

最新評論