摘要:后端路由簡介路由這個概念最先是后端出現(xiàn)的。前端路由模式隨著的流行,異步數(shù)據(jù)請求交互運(yùn)行在不刷新瀏覽器的情況下進(jìn)行。通過這些就能用另一種方式來實(shí)現(xiàn)前端路由了,但原理都是跟實(shí)現(xiàn)相同的。
后端路由簡介
路由這個概念最先是后端出現(xiàn)的。在以前用模板引擎開發(fā)頁面時,經(jīng)常會看到這樣
http://www.xxx.com/login
大致流程可以看成這樣:
瀏覽器發(fā)出請求
服務(wù)器監(jiān)聽到80端口(或443)有請求過來,并解析url路徑
根據(jù)服務(wù)器的路由配置,返回相應(yīng)信息(可以是 html 字串,也可以是 json 數(shù)據(jù),圖片等)
瀏覽器根據(jù)數(shù)據(jù)包的 Content-Type 來決定如何解析數(shù)據(jù)
簡單來說路由就是用來跟后端服務(wù)器進(jìn)行交互的一種方式,通過不同的路徑,來請求不同的資源,請求不同的頁面是路由的其中一種功能。
前端路由 1. hash 模式隨著 ajax 的流行,異步數(shù)據(jù)請求交互運(yùn)行在不刷新瀏覽器的情況下進(jìn)行。而異步交互體驗(yàn)的更高級版本就是 SPA —— 單頁應(yīng)用。單頁應(yīng)用不僅僅是在頁面交互是無刷新的,連頁面跳轉(zhuǎn)都是無刷新的,為了實(shí)現(xiàn)單頁應(yīng)用,所以就有了前端路由。
類似于服務(wù)端路由,前端路由實(shí)現(xiàn)起來其實(shí)也很簡單,就是匹配不同的 url 路徑,進(jìn)行解析,然后動態(tài)的渲染出區(qū)域 html 內(nèi)容。但是這樣存在一個問題,就是 url 每次變化的時候,都會造成頁面的刷新。那解決問題的思路便是在改變 url 的情況下,保證頁面的不刷新。在 2014 年之前,大家是通過 hash 來實(shí)現(xiàn)路由,url hash 就是類似于:
http://www.xxx.com/#/login
這種 #。后面 hash 值的變化,并不會導(dǎo)致瀏覽器向服務(wù)器發(fā)出請求,瀏覽器不發(fā)出請求,也就不會刷新頁面。另外每次 hash 值的變化,還會觸發(fā)hashchange 這個事件,通過這個事件我們就可以知道 hash 值發(fā)生了哪些變化。然后我們便可以監(jiān)聽hashchange來實(shí)現(xiàn)更新頁面部分內(nèi)容的操作:
function matchAndUpdate () { // todo 匹配 hash 做 dom 更新操作 } window.addEventListener("hashchange", matchAndUpdate)2. history 模式
14年后,因?yàn)镠TML5標(biāo)準(zhǔn)發(fā)布。多了兩個 API,pushState 和 replaceState,通過這兩個 API 可以改變 url 地址且不會發(fā)送請求。同時還有 popstate 事件。通過這些就能用另一種方式來實(shí)現(xiàn)前端路由了,但原理都是跟 hash 實(shí)現(xiàn)相同的。用了 HTML5 的實(shí)現(xiàn),單頁路由的 url 就不會多出一個#,變得更加美觀。但因?yàn)闆]有 # 號,所以當(dāng)用戶刷新頁面之類的操作時,瀏覽器還是會給服務(wù)器發(fā)送請求。為了避免出現(xiàn)這種情況,所以這個實(shí)現(xiàn)需要服務(wù)器的支持,需要把所有路由都重定向到根頁面。
function matchAndUpdate () { // todo 匹配路徑 做 dom 更新操作 } window.addEventListener("popstate", matchAndUpdate)Vue router 實(shí)現(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的方法被注入進(jìn) Vue 實(shí)例中,在使用的時候我們需要全局用到 vue-router的router-view和router-link組件,以及this.$router/$route這樣的實(shí)例對象。那么是如何實(shí)現(xiàn)這些操作的呢?下面我會分幾個章節(jié)詳細(xì)的帶你進(jìn)入vue-router的世界。(閱讀源碼是有點(diǎn)枯燥,但是帶著問題去了解,就感覺很有意思。如果你對 vue-router 的實(shí)現(xiàn)機(jī)制也存在一些疑問,可以一起探討交流)
vue-router 實(shí)現(xiàn) -- install
vue-router 實(shí)現(xiàn) -- new VueRouter(options)
vue-router 實(shí)現(xiàn) -- HashHistory
未完待續(xù)...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://www.ezyhdfw.cn/yun/107879.html
摘要:而路由則是使用了中新增的事件和事件??偨Y(jié)這一章主要是介紹了如何使用在中構(gòu)建我們的前端路由。 系列目錄地址 一、基礎(chǔ)知識概覽 第一章 - 一些基礎(chǔ)概念(posted at 2018-10-31) 第二章 - 常見的指令的使用(posted at 2018-11-01) 第三章 - 事件修飾符的使用(posted at 2018-11-02) 第四章 - 頁面元素樣式的設(shè)定(posted a...
摘要:注意這個功能只在支持的瀏覽器中可用。官方文檔簡介滾動行為使用方法期望滾動到哪個的位置或者集成模式寫法期望滾動到哪個的位置方法接收和路由對象。 前提:之前寫過關(guān)于keep-Alive組件,來實(shí)現(xiàn)在列表頁進(jìn)入詳情頁后,后退,返回列表,顯示上次訪問的位置(原理就是緩存列表頁數(shù)據(jù)來實(shí)現(xiàn)),目前發(fā)現(xiàn)另外一個問題,就是如果后臺操作改變數(shù)據(jù)的狀態(tài),緩存的辦法就會導(dǎo)致數(shù)據(jù)更新不及時導(dǎo)致一些頁面錯誤(例...
前言 本文所有內(nèi)容全部發(fā)布再個人博客主頁 https://github.com/muwoo/blogs歡迎訂閱。不過最近因?yàn)槭虑楸容^多,有一段時間沒有更新了,后面打算繼續(xù)不斷學(xué)習(xí)更新,歡迎小伙伴一起溝通交流~ 最近更新 前端單測的那些事 基于virtual dom 的canvas渲染 js Event loop 機(jī)制簡介 axios 核心源碼實(shí)現(xiàn)原理 JS 數(shù)據(jù)類型、賦值、深拷貝和淺拷貝 j...
閱讀 1600·2021-11-25 09:43
閱讀 4158·2021-11-15 11:37
閱讀 3263·2021-08-17 10:13
閱讀 3571·2019-08-30 14:16
閱讀 3601·2019-08-26 18:37
閱讀 2545·2019-08-26 11:56
閱讀 1211·2019-08-26 10:42
閱讀 698·2019-08-26 10:39