国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

淺析前端路由簡介以及vue-router實現(xiàn)原理

來源:懂視網 責編:小采 時間:2020-11-27 22:13:40
文檔

淺析前端路由簡介以及vue-router實現(xiàn)原理

淺析前端路由簡介以及vue-router實現(xiàn)原理:路由這個概念最先是后端出現(xiàn)的。在以前用模板引擎開發(fā)頁面時,經常會看到這樣 http://www.xxx.com/login 大致流程可以看成這樣: 瀏覽器發(fā)出請求 服務器監(jiān)聽到80端口(或443)有請求過來,并解析url路徑 根據(jù)服務器的路由配置,返回相應信息(可以是 htm
推薦度:
導讀淺析前端路由簡介以及vue-router實現(xiàn)原理:路由這個概念最先是后端出現(xiàn)的。在以前用模板引擎開發(fā)頁面時,經常會看到這樣 http://www.xxx.com/login 大致流程可以看成這樣: 瀏覽器發(fā)出請求 服務器監(jiān)聽到80端口(或443)有請求過來,并解析url路徑 根據(jù)服務器的路由配置,返回相應信息(可以是 htm

路由這個概念最先是后端出現(xiàn)的。在以前用模板引擎開發(fā)頁面時,經常會看到這樣

http://www.xxx.com/login

大致流程可以看成這樣:

  1. 瀏覽器發(fā)出請求
  2. 服務器監(jiān)聽到80端口(或443)有請求過來,并解析url路徑
  3. 根據(jù)服務器的路由配置,返回相應信息(可以是 html 字串,也可以是 json 數(shù)據(jù),圖片等)
  4. 瀏覽器根據(jù)數(shù)據(jù)包的 Content-Type 來決定如何解析數(shù)據(jù)

簡單來說路由就是用來跟后端服務器進行交互的一種方式,通過不同的路徑,來請求不同的資源,請求不同的頁面是路由的其中一種功能。

前端路由

1. hash 模式

隨著 ajax 的流行,異步數(shù)據(jù)請求交互運行在不刷新瀏覽器的情況下進行。而異步交互體驗的更高級版本就是 SPA —— 單頁應用。單頁應用不僅僅是在頁面交互是無刷新的,連頁面跳轉都是無刷新的,為了實現(xiàn)單頁應用,所以就有了前端路由。 類似于服務端路由,前端路由實現(xiàn)起來其實也很簡單,就是匹配不同的 url 路徑,進行解析,然后動態(tài)的渲染出區(qū)域 html 內容。但是這樣存在一個問題,就是 url 每次變化的時候,都會造成頁面的刷新。那解決問題的思路便是在改變 url 的情況下,保證頁面的不刷新。在 2014 年之前,大家是通過 hash 來實現(xiàn)路由,url hash 就是類似于:

http://www.xxx.com/#/login

這種 #。后面 hash 值的變化,并不會導致瀏覽器向服務器發(fā)出請求,瀏覽器不發(fā)出請求,也就不會刷新頁面。另外每次 hash 值的變化,還會觸發(fā) hashchange 這個事件,通過這個事件我們就可以知道 hash 值發(fā)生了哪些變化。然后我們便可以監(jiān)聽 hashchange 來實現(xiàn)更新頁面部分內容的操作:

function matchAndUpdate () {
 // todo 匹配 hash 做 dom 更新操作
}
window.addEventListener('hashchange', matchAndUpdate)

2. history 模式

14年后,因為HTML5標準發(fā)布。多了兩個 API, pushState 和 replaceState ,通過這兩個 API 可以改變 url 地址且不會發(fā)送請求。同時還有 popstate 事件。通過這些就能用另一種方式來實現(xiàn)前端路由了,但原理都是跟 hash 實現(xiàn)相同的。用了 HTML5 的實現(xiàn),單頁路由的 url 就不會多出一個#,變得更加美觀。但因為沒有 # 號,所以當用戶刷新頁面之類的操作時,瀏覽器還是會給服務器發(fā)送請求。為了避免出現(xiàn)這種情況,所以這個實現(xiàn)需要服務器的支持,需要把所有路由都重定向到根頁面。

function matchAndUpdate () {
 // todo 匹配路徑 做 dom 更新操作
}
window.addEventListener('popstate', matchAndUpdate)

Vue router 實現(xiàn)

我們來看一下 vue-router 是如何定義的:

import VueRouter from 'vue-router'
Vue.use(VueRouter)
const router = new VueRouter({
 mode: 'history',
 routes: [...]
})
new Vue({
 router
 ...
})

可以看出來 vue-router 是通過 Vue.use 的方法被注入進 Vue 實例中,在使用的時候我們需要全局用到 vue-router 的 router-view 和 router-link 組件,以及 this.$router/$route 這樣的實例對象。那么是如何實現(xiàn)這些操作的呢?下面我會分幾個章節(jié)詳細的帶你進入 vue-router 的世界。(閱讀源碼是有點枯燥,但是帶著問題去了解,就感覺很有意思。如果你對 vue-router 的實現(xiàn)機制也存在一些疑問,可以一起探討交流)

vue-router 實現(xiàn) -- install

vue-router 實現(xiàn) -- new VueRouter(options)

vue-router 實現(xiàn) -- HashHistory

未完待續(xù)...

更多 blog

總結

以上所述是小編給大家介紹的前端路由簡介以及vue-router實現(xiàn)原理,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

淺析前端路由簡介以及vue-router實現(xiàn)原理

淺析前端路由簡介以及vue-router實現(xiàn)原理:路由這個概念最先是后端出現(xiàn)的。在以前用模板引擎開發(fā)頁面時,經常會看到這樣 http://www.xxx.com/login 大致流程可以看成這樣: 瀏覽器發(fā)出請求 服務器監(jiān)聽到80端口(或443)有請求過來,并解析url路徑 根據(jù)服務器的路由配置,返回相應信息(可以是 htm
推薦度:
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 免费观看的黄色网址 | 亚洲国产成人精品一区二区三区 | 青青草原国产一区二区 | 国产欧美日韩综合 | 在线v片| 欧美大陆日韩 | 在线免费观看国产视频 | 国产va在线视频观看 | 国产欧美中文字幕 | 精品国产一区二区三区在线 | 国产v片在线观看 | 欧美日韩影院 | 97伊人 | 午夜影院欧美 | 青青草国产在线视频 | 91香蕉福利一区二区三区 | 欧美日韩国产高清视频 | 精品日韩二区三区精品视频 | 欧美日韩极品 | 毛片免费网址 | 国产精品亚洲αv天堂2021 | 一区二区视频在线播放 | 亚洲欧美在线观看 | 亚洲视频一区二区 | 日韩欧美在线观看视频 | 亚洲欧美综合网站 | 免费观看h | 国产视频最新 | 成人精品一区二区www | 在线播放精品一区二区啪视频 | 久久亚洲一区二区 | 国产精品v一区二区三区 | 国产免费网址 | 碰91精品国产91久久婷婷 | 日本国产最新一区二区三区 | 国产成人91一区二区三区 | 特级全黄一级毛片视频 | 精品久久久久久亚洲 | 综合亚洲一区二区三区 | 亚洲欧美日韩激情在线观看 | 91亚洲欧美综合高清在线 |