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

Vue路由前后端設計總結

 更新時間:2019年08月06日 15:46:03   作者:陽光男孩  
在本篇文章里小編給大家整理的是關于Vue路由前后端設計的知識點總結內容,需要的朋友們參考下。

一開始我還以為vue的路由只能用在工程化的項目里面呢,然后研究了一下才發(fā)現(xiàn),在腳本化里面也是可以用的。其實呢不管在哪里用,把原理研究明白就對了。

一、 官網(wǎng)demo

這里不得不吐槽一下官網(wǎng),寫的不清不楚的,在哪里使用都沒有說清楚,幾行代碼一句話就輕飄飄的交代完事了,剩下的事情還得自己研究,比如 HTML5 History API 是怎么回事。這里又涉及了一個問題,想要用好vue,必須的基礎是要先掌握的,因為vue的官網(wǎng)教程里面不會管這些基礎知識的。

先看官網(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) }
})

很簡單吧就這么幾句,浪費了我好多時間才研究明白。恩,好吧還有一個地方每太明白。

首先定義了三個“常量”,就是不能改的那種變量,代表三個頁面,或者說是三個模板。分別是404、首頁和關于我們。

然后定義了一個路由規(guī)則,其實就是一個json,也可以理解為是一個實體類。Key代表url的地址后面的路徑和文件名,后面的是我們的真實頁面,也就是第一行定義的三個常量。

然后就是常見的vue的實例了,首先需要一個div與之對應,然后是data返回url上面的地址,然后ViewComponent 是根據(jù)url地址返回對應的模板(頁面)。

最后是render 。大概是實現(xiàn)綁定div的功能吧。

根據(jù)這個意思補充了一個頁面

 <body>
   <span onclick="myURL('/')">首頁</span>
   <span onclick="myURL('/about')">關于</span>
   <div id="app"></div>
 </body>

然后呢,運行網(wǎng)頁顯示 Page not found 404 ,看來路由還是起作用了。那么home和about要怎么出來呢?

二、HTML5 History API

首先要補充一下 HTML5 History API的相關知識,如果已經(jīng)掌握了那么請略過。

HTML5 History API提供了一種功能,能讓開發(fā)人員在不刷新整個頁面的情況下修改站點的URL。這個功能很有用,例如通過一段JavaScript代碼局部加載頁面的內容,你希望通過改變當前頁面的URL來反應出頁面內容的變化,這時該功能可以派上用場。

我們可以用 history.pushState(null, null, ‘a(chǎn)bout'); 來改變url地址,這種方式只是單純的修改地址里的url,而不會向服務器提交,這樣頁面就不會被刷新,我們才有機會執(zhí)行vue的代碼。

然后呢,頁面當然是不會有啥變化的,因為vue是數(shù)據(jù)驅動,我們的數(shù)據(jù)改變了嗎?并沒有,我們只是改變了一下url。這個vue似乎沒有對rul做監(jiān)聽,或者是我還不知道怎么讓vue去監(jiān)聽url的變化,總之我們先自己改變數(shù)據(jù),然后再去研究vue有沒有辦法去監(jiān)聽url。

我們在寫一行修改數(shù)據(jù)的代碼route.currentRoute = window.location.pathname就可以了。

最后加一個簡單的導航,執(zhí)行上面兩行js代碼。

<span onclick="myURL('/')">首頁</span>
<span onclick="myURL('/about')">關于</span>

function myURL(name) {
    history.pushState(null, null, name);
    route.currentRoute = window.location.pathname;
}

三、按了F5怎么辦?

按F5會刷新頁面,如果這時候url地址欄是 “/about” ,那么就會向服務器提交這個網(wǎng)址,很顯然會出現(xiàn)服務器的404頁面。因為服務器網(wǎng)站里面并沒有這個地址。那么怎么辦呢?目前想到的辦法就是修改網(wǎng)站的404頁面。比如IIS,可以到IIS里改一下,把我們做的這個router.html設置為404的響應頁面,這樣按F5就沒事了。

當然這種方式并不是太好的選擇,只是一種臨時的方法。應該會有更好的方法吧。沒事不急慢慢學。

這種方式還支持直接在瀏覽器的地址欄里面輸入 http://127.0.0.1:8000/about 也是可以正常運行的。只需要注意一下vue.js的引用地址確保能夠正確加載js文件即可。

那么如果地址欄里輸入 http://127.0.0.1:8000/aboutss 呢?當然是vue設計的404模塊了。

不過還有一個問題,那個 const About 要怎么改?這種簡單的模板沒辦法做復雜應用的呀。也許只有在工程化的項目里,路由才能發(fā)揮最大的作用吧。

感謝大家的閱讀和對腳本之家的支持。

相關文章

  • vue如何使用mapbox對當前行政區(qū)劃進行反選遮罩

    vue如何使用mapbox對當前行政區(qū)劃進行反選遮罩

    這篇文章主要介紹了vue如何使用mapbox對當前行政區(qū)劃進行反選遮罩問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vant 時間選擇器--開始時間和結束時間實例

    vant 時間選擇器--開始時間和結束時間實例

    這篇文章主要介紹了vant 時間選擇器--開始時間和結束時間實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Vue關鍵字搜索功能實戰(zhàn)小案例

    Vue關鍵字搜索功能實戰(zhàn)小案例

    在vue項目中,搜索功能是我們經(jīng)常需要使用的一個場景,下面這篇文章主要給大家介紹了關于Vue關鍵字搜索功能的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-06-06
  • Vue同一路由強制刷新頁面的實現(xiàn)過程

    Vue同一路由強制刷新頁面的實現(xiàn)過程

    這篇文章主要介紹了解決VUE同一路由強制刷新頁面的問題,本文給大家分享實現(xiàn)過程,通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • vue路由傳參三種基本方式詳解

    vue路由傳參三種基本方式詳解

    這篇文章主要介紹了vue路由傳參三種基本方式詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-12-12
  • vue實現(xiàn)右上角時間顯示實時刷新

    vue實現(xiàn)右上角時間顯示實時刷新

    這篇文章主要為大家詳細介紹了vue實現(xiàn)右上角時間顯示實時刷新,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • vue-editor-bridge報錯的解決方案

    vue-editor-bridge報錯的解決方案

    這篇文章主要介紹了vue-editor-bridge報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue選項之propsData傳遞數(shù)據(jù)方式

    Vue選項之propsData傳遞數(shù)據(jù)方式

    這篇文章主要介紹了Vue選項之propsData傳遞數(shù)據(jù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 詳解新手使用vue-router傳參時注意事項

    詳解新手使用vue-router傳參時注意事項

    這篇文章主要介紹了詳解新手使用vue-router傳參時注意事項,詳細的介紹了幾種常見錯誤,需要的朋友們下面隨著小編來一起學習學習吧
    2019-06-06
  • Vue淺析講解動態(tài)組件與緩存組件及異步組件的使用

    Vue淺析講解動態(tài)組件與緩存組件及異步組件的使用

    這篇文章主要介紹了Vue開發(fā)中的動態(tài)組件與緩存組件及異步組件的使用教程,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-09-09

最新評論