Vue路由前后端設(shè)計(jì)總結(jié)
一開(kāi)始我還以為vue的路由只能用在工程化的項(xiàng)目里面呢,然后研究了一下才發(fā)現(xiàn),在腳本化里面也是可以用的。其實(shí)呢不管在哪里用,把原理研究明白就對(duì)了。
一、 官網(wǎng)demo
這里不得不吐槽一下官網(wǎng),寫(xiě)的不清不楚的,在哪里使用都沒(méi)有說(shuō)清楚,幾行代碼一句話就輕飄飄的交代完事了,剩下的事情還得自己研究,比如 HTML5 History API 是怎么回事。這里又涉及了一個(gè)問(wèn)題,想要用好vue,必須的基礎(chǔ)是要先掌握的,因?yàn)関ue的官網(wǎng)教程里面不會(huì)管這些基礎(chǔ)知識(shí)的。
先看官網(wǎng)的代碼:
const NotFound = { template: '<p>Page not found</p>' }
const Home = { template: '<p>home page</p>' }
const About = { template: '<p>about page</p>' }
const routes = {
'/': Home,
'/about': About
}
new Vue({
el: '#app',
data: {
currentRoute: window.location.pathname
},
computed: {
ViewComponent () {
return routes[this.currentRoute] || NotFound
}
},
render (h) { return h(this.ViewComponent) }
})
很簡(jiǎn)單吧就這么幾句,浪費(fèi)了我好多時(shí)間才研究明白。恩,好吧還有一個(gè)地方每太明白。
首先定義了三個(gè)“常量”,就是不能改的那種變量,代表三個(gè)頁(yè)面,或者說(shuō)是三個(gè)模板。分別是404、首頁(yè)和關(guān)于我們。
然后定義了一個(gè)路由規(guī)則,其實(shí)就是一個(gè)json,也可以理解為是一個(gè)實(shí)體類(lèi)。Key代表url的地址后面的路徑和文件名,后面的是我們的真實(shí)頁(yè)面,也就是第一行定義的三個(gè)常量。
然后就是常見(jiàn)的vue的實(shí)例了,首先需要一個(gè)div與之對(duì)應(yīng),然后是data返回url上面的地址,然后ViewComponent 是根據(jù)url地址返回對(duì)應(yīng)的模板(頁(yè)面)。
最后是render 。大概是實(shí)現(xiàn)綁定div的功能吧。
根據(jù)這個(gè)意思補(bǔ)充了一個(gè)頁(yè)面
<body>
<span onclick="myURL('/')">首頁(yè)</span>
<span onclick="myURL('/about')">關(guān)于</span>
<div id="app"></div>
</body>
然后呢,運(yùn)行網(wǎng)頁(yè)顯示 Page not found 404 ,看來(lái)路由還是起作用了。那么home和about要怎么出來(lái)呢?
二、HTML5 History API
首先要補(bǔ)充一下 HTML5 History API的相關(guān)知識(shí),如果已經(jīng)掌握了那么請(qǐng)略過(guò)。
HTML5 History API提供了一種功能,能讓開(kāi)發(fā)人員在不刷新整個(gè)頁(yè)面的情況下修改站點(diǎn)的URL。這個(gè)功能很有用,例如通過(guò)一段JavaScript代碼局部加載頁(yè)面的內(nèi)容,你希望通過(guò)改變當(dāng)前頁(yè)面的URL來(lái)反應(yīng)出頁(yè)面內(nèi)容的變化,這時(shí)該功能可以派上用場(chǎng)。
我們可以用 history.pushState(null, null, ‘a(chǎn)bout'); 來(lái)改變url地址,這種方式只是單純的修改地址里的url,而不會(huì)向服務(wù)器提交,這樣頁(yè)面就不會(huì)被刷新,我們才有機(jī)會(huì)執(zhí)行vue的代碼。
然后呢,頁(yè)面當(dāng)然是不會(huì)有啥變化的,因?yàn)関ue是數(shù)據(jù)驅(qū)動(dòng),我們的數(shù)據(jù)改變了嗎?并沒(méi)有,我們只是改變了一下url。這個(gè)vue似乎沒(méi)有對(duì)rul做監(jiān)聽(tīng),或者是我還不知道怎么讓vue去監(jiān)聽(tīng)url的變化,總之我們先自己改變數(shù)據(jù),然后再去研究vue有沒(méi)有辦法去監(jiān)聽(tīng)url。
我們?cè)趯?xiě)一行修改數(shù)據(jù)的代碼route.currentRoute = window.location.pathname就可以了。
最后加一個(gè)簡(jiǎn)單的導(dǎo)航,執(zhí)行上面兩行js代碼。
<span onclick="myURL('/')">首頁(yè)</span>
<span onclick="myURL('/about')">關(guān)于</span>
function myURL(name) {
history.pushState(null, null, name);
route.currentRoute = window.location.pathname;
}
三、按了F5怎么辦?
按F5會(huì)刷新頁(yè)面,如果這時(shí)候url地址欄是 “/about” ,那么就會(huì)向服務(wù)器提交這個(gè)網(wǎng)址,很顯然會(huì)出現(xiàn)服務(wù)器的404頁(yè)面。因?yàn)榉?wù)器網(wǎng)站里面并沒(méi)有這個(gè)地址。那么怎么辦呢?目前想到的辦法就是修改網(wǎng)站的404頁(yè)面。比如IIS,可以到IIS里改一下,把我們做的這個(gè)router.html設(shè)置為404的響應(yīng)頁(yè)面,這樣按F5就沒(méi)事了。
當(dāng)然這種方式并不是太好的選擇,只是一種臨時(shí)的方法。應(yīng)該會(huì)有更好的方法吧。沒(méi)事不急慢慢學(xué)。
這種方式還支持直接在瀏覽器的地址欄里面輸入 http://127.0.0.1:8000/about 也是可以正常運(yùn)行的。只需要注意一下vue.js的引用地址確保能夠正確加載js文件即可。
那么如果地址欄里輸入 http://127.0.0.1:8000/aboutss 呢?當(dāng)然是vue設(shè)計(jì)的404模塊了。
不過(guò)還有一個(gè)問(wèn)題,那個(gè) const About 要怎么改?這種簡(jiǎn)單的模板沒(méi)辦法做復(fù)雜應(yīng)用的呀。也許只有在工程化的項(xiàng)目里,路由才能發(fā)揮最大的作用吧。
感謝大家的閱讀和對(duì)腳本之家的支持。
相關(guān)文章
Vue項(xiàng)目在IE瀏覽器的兼容問(wèn)題及解決方法
該文章主要介紹了如何在Vue項(xiàng)目中解決IE瀏覽器的兼容性問(wèn)題,包括解決IE不兼容axios的Promise對(duì)象、ES6語(yǔ)法以及polyfill的使用方法,通過(guò)配置babel-polyfill、es6-promise和轉(zhuǎn)ES5語(yǔ)法,解決了在IE瀏覽器中常見(jiàn)的兼容性問(wèn)題,需要的朋友可以參考下2025-01-01
Vue.js簡(jiǎn)易安裝和快速入門(mén)(第二課)
這篇文章主要為大家詳細(xì)介紹了Vue.js簡(jiǎn)易安裝和快速入門(mén)的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10
細(xì)說(shuō)Vue組件的服務(wù)器端渲染的過(guò)程
這篇文章主要介紹了細(xì)說(shuō) Vue 組件的服務(wù)器端渲染,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-05-05
詳解vue-element Tree樹(shù)形控件填坑路
這篇文章主要介紹了vue-element Tree樹(shù)形控件填坑路,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
利用vue組件實(shí)現(xiàn)圖片的拖拽和縮放功能
這篇文章主要給大家介紹了關(guān)于利用vue組件實(shí)現(xiàn)圖片的拖拽和縮放功能的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-01-01
完美解決通過(guò)IP地址訪問(wèn)VUE項(xiàng)目的問(wèn)題
這篇文章主要介紹了完美解決通過(guò)IP地址訪問(wèn)VUE項(xiàng)目的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07
在VUE3中禁止網(wǎng)頁(yè)返回到上一頁(yè)的方法
這篇文章主要介紹了在VUE3中如何禁止網(wǎng)頁(yè)返回到上一頁(yè),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09

