下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第Vue路由前后端設(shè)計(jì)總結(jié)一開(kāi)始我還以為vue的路由只能用在工程化的項(xiàng)目里面呢,然后研究了一下才發(fā)現(xiàn),在腳本化里面也是可以用的。其實(shí)呢不管在哪里用,把原理研究明白就對(duì)了。
一、官網(wǎng)demo
這里不得不吐槽一下官網(wǎng),寫的不清不楚的,在哪里使用都沒(méi)有說(shuō)清楚,幾行代碼一句話就輕飄飄的交代完事了,剩下的事情還得自己研究,比如HTML5HistoryAPI是怎么回事。這里又涉及了一個(gè)問(wèn)題,想要用好vue,必須的基礎(chǔ)是要先掌握的,因?yàn)関ue的官網(wǎng)教程里面不會(huì)管這些基礎(chǔ)知識(shí)的。
先看官網(wǎng)的代碼:
constNotFound={template:'pPagenotfound/p'}
constHome={template:'phomepage/p'}
constAbout={template:'paboutpage/p'}
constroutes={
'/':Home,
'/about':About
newVue({
el:'#app',
data:{
currentRoute:window.location.pathname
computed:{
ViewComponent(){
returnroutes[this.currentRoute]||NotFound
render(h){returnh(this.ViewComponent)}
})
很簡(jiǎn)單吧就這么幾句,浪費(fèi)了我好多時(shí)間才研究明白。恩,好吧還有一個(gè)地方每太明白。
首先定義了三個(gè)“常量”,就是不能改的那種變量,代表三個(gè)頁(yè)面,或者說(shuō)是三個(gè)模板。分別是404、首頁(yè)和關(guān)于我們。
然后定義了一個(gè)路由規(guī)則,其實(shí)就是一個(gè)json,也可以理解為是一個(gè)實(shí)體類。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首頁(yè)/span
span關(guān)于/span
divid="app"/div
/body
然后呢,運(yùn)行網(wǎng)頁(yè)顯示Pagenotfound404,看來(lái)路由還是起作用了。那么home和about要怎么出來(lái)呢?
二、HTML5HistoryAPI
首先要補(bǔ)充一下HTML5HistoryAPI的相關(guān)知識(shí),如果已經(jīng)掌握了那么請(qǐng)略過(guò)。
HTML5HistoryAPI提供了一種功能,能讓開(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è)趯懸恍行薷臄?shù)據(jù)的代碼route.currentRoute=window.location.pathname就可以了。
最后加一個(gè)簡(jiǎn)單的導(dǎo)航,執(zhí)行上面兩行js代碼。
span首頁(yè)/span
span關(guān)于/span
functionmyURL(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é)。
這種方式還支持直接在瀏覽器的地址欄里面輸入:8000/about也是可以正常運(yùn)行的。只需要注意一下vue.js的引用地址確保能夠正確加載js文件即可。
那么如果地址欄里輸入:8000/aboutss
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 公關(guān)公司媒介管理制度(3篇)
- 2026年泰安新泰市事業(yè)單位初級(jí)綜合類崗位公開(kāi)招聘工作人員(76人)參考考試題庫(kù)及答案解析
- 2026廈門國(guó)際銀行福建寧德分行校園招聘?jìng)淇伎荚囶}庫(kù)及答案解析
- 讀不完的大書(shū)第二課時(shí)
- 2026年贛州市第十中學(xué)春季學(xué)期頂崗教師招聘?jìng)淇伎荚囋囶}及答案解析
- 2026四川樂(lè)山馬邊彝族自治縣婦幼保健計(jì)劃生育服務(wù)中心招聘4人備考考試題庫(kù)及答案解析
- 2026年上半年黑龍江省地震局事業(yè)單位公開(kāi)招聘工作人員2人考試參考試題及答案解析
- 2026年上半年四川中醫(yī)藥高等??茖W(xué)校第一批編外教職工招聘7人參考考試題庫(kù)及答案解析
- 2026內(nèi)蒙古直屬機(jī)關(guān)(參公單位)遴選公務(wù)員考試參考試題及答案解析
- 2026年上半年大慶市事業(yè)單位公開(kāi)招聘工作人員164人筆試參考題庫(kù)及答案解析
- 2025年社區(qū)工作總結(jié)及2026年工作計(jì)劃
- 南昌地鐵培訓(xùn)課件
- GB/T 30104.104-2025數(shù)字可尋址照明接口第104部分:一般要求無(wú)線和其他有線系統(tǒng)組件
- 三年級(jí)上冊(cè)數(shù)學(xué)第三單元題型專項(xiàng)訓(xùn)練-判斷題(解題策略專項(xiàng)秀場(chǎng))人教版(含答案)
- 湖南省婁底市新化縣2024-2025學(xué)年高一上學(xué)期期末考試生物試題(解析版)
- GB/T 45629.1-2025信息技術(shù)數(shù)據(jù)中心設(shè)備和基礎(chǔ)設(shè)施第1部分:通用概念
- 2025年中考?xì)v史開(kāi)卷考查范圍重大考點(diǎn)全突破(完整版)
- 學(xué)術(shù)誠(chéng)信與學(xué)術(shù)規(guī)范研究-深度研究
- 《ETF相關(guān)知識(shí)培訓(xùn)》課件
- DB15-T 3677-2024 大興安嶺林區(qū)白樺樹(shù)汁采集技術(shù)規(guī)程
- 2024年《13464電腦動(dòng)畫》自考復(fù)習(xí)題庫(kù)(含答案)
評(píng)論
0/150
提交評(píng)論