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

Vue?前端路由工作原理hash與history的區(qū)別

 更新時間:2022年07月05日 16:28:17   作者:??MMN??  
這篇文章主要介紹了Vue?前端路由工作原理hash與history的區(qū)別,文章圍繞主題展開vue-router的工作原理的簡單介紹,感興趣的朋友可以學習一下

什么是路由?

路由分兩種:

  • 前端路由:Hash 地址與組件之間的對應關系
  • 后端路由:瀏覽器 請求地址+請求方式 與 后端 業(yè)務邏輯 之間的一個映射關系

SPA與前端路由:

 SPA (單頁面應用,全稱為:Single-page Web applications) 指的是一個 web 網(wǎng)站只有唯一的一個 HTML 頁面,所有組件的展示與切換都在這唯一的一個頁面內(nèi)完成,此時,不同組件之間的切換需要通過前端路由來實現(xiàn)

vue-router的工作原理

vue-router通過hash與History interface兩種方式實現(xiàn)前端路由,更新視圖但不重新請求頁面”是前端路由原理的核心之一,目前在瀏覽器環(huán)境中這一功能的實現(xiàn)主要有兩種方式:

  • 利用URL中的hash(“#”)
  • 利用History interface在 HTML5中新增的方法

在vue-router中,它提供了mode參數(shù)來決定采用哪一種方式 mode參數(shù):

  • 默認hash
  • 手動設置為history

router/index.js文件代碼

那么,兩者的區(qū)別是什么呢?

1.mode:'hash',在URL中會多'#'

  • vue-router默認為hash模式,使用URL的hash來模擬一個完整的URL,當URL改變時,頁面不會重新加載。#就是hash符號,中文名為哈希符或者錨點,在hash符號后的值稱為hash值。
  • 路由的hash模式是利用了window可以監(jiān)聽onhashchange事件來實現(xiàn)的,也就是說hash值是用來指導瀏覽器動作的,對服務器沒有影響,HTTP 請求中也不會包括hash值,同時每一次改變hash值,都會在瀏覽器的訪問歷史中增加一個記錄,使用“后退”按鈕,就可以回到上一個位置。所以,hash 模式是根據(jù)hash值來發(fā)生改變,根據(jù)不同的值,渲染指定DOM位置的不同數(shù)據(jù)。

2.mode:'history'

  • 當你使用 history 模式時,URL 就像正常的 url,例如 http://yoursite.com/user/id,也好看!

不過這種模式要玩好,還需要后臺配置支持。因為我們的應用是個單頁客戶端應用,如果后臺沒有正確的配置,當用戶在瀏覽器直接訪問 http://oursite.com/user/id 就會返回 404,這就不好看了。

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

到此這篇關于Vue 前端路由工作原理hash與history的區(qū)別的文章就介紹到這了,更多相關Vue hash與history內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Element-UI日期選擇器(選擇日期范圍)禁用未來日期實現(xiàn)代碼

    Element-UI日期選擇器(選擇日期范圍)禁用未來日期實現(xiàn)代碼

    我們在網(wǎng)頁開發(fā)時通常需要用到一些日期組件來方便用戶選擇時間,其中element日期組件是一個非常好用的工具,這篇文章主要給大家介紹了關于Element-UI日期選擇器(選擇日期范圍)禁用未來日期的相關資料,需要的朋友可以參考下
    2024-02-02
  • vue實現(xiàn)拖拽或點擊上傳圖片

    vue實現(xiàn)拖拽或點擊上傳圖片

    這篇文章主要為大家詳細介紹了vue實現(xiàn)拖拽或點擊上傳圖片,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • vue實現(xiàn)驗證用戶名是否可用

    vue實現(xiàn)驗證用戶名是否可用

    這篇文章主要為大家詳細介紹了vue實現(xiàn)驗證用戶名是否可用,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • vue.js中修飾符.stop的用法解析

    vue.js中修飾符.stop的用法解析

    這篇文章主要介紹了vue.js中修飾符.stop的用法解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Vue?router應用問題實戰(zhàn)記錄

    Vue?router應用問題實戰(zhàn)記錄

    vue-router是vue.js官方的路由插件,他和vue.js是深度集成的適合構建單頁面應用,下面這篇文章主要給大家介紹了關于Vue?router應用問題的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-04-04
  • html頁面引入vue組件之http-vue-loader.js解讀

    html頁面引入vue組件之http-vue-loader.js解讀

    這篇文章主要介紹了html頁面引入vue組件之http-vue-loader.js解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue網(wǎng)站優(yōu)化實戰(zhàn)之秒開網(wǎng)頁

    vue網(wǎng)站優(yōu)化實戰(zhàn)之秒開網(wǎng)頁

    最近在搭建自己的博客,前端采用Vue技術,發(fā)現(xiàn)首頁加載速度非常之慢,常常達到10S左右,遂開始優(yōu)化之旅,這篇文章主要給大家介紹了關于vue網(wǎng)站優(yōu)化實戰(zhàn)之秒開網(wǎng)頁的相關資料,需要的朋友可以參考下
    2022-08-08
  • element中el-cascader級聯(lián)選擇器只有最后一級可以多選

    element中el-cascader級聯(lián)選擇器只有最后一級可以多選

    本文主要介紹了element中el-cascader級聯(lián)選擇器只有最后一級可以多選,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-01-01
  • Element Dialog對話框的使用示例

    Element Dialog對話框的使用示例

    這篇文章主要介紹了Element Dialog對話框的使用示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • vue學習之Vue-Router用法實例分析

    vue學習之Vue-Router用法實例分析

    這篇文章主要介紹了vue學習之Vue-Router用法,結(jié)合實例形式分析了Vue-Router路由原理與常見操作技巧,需要的朋友可以參考下
    2020-01-01

最新評論