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

Vue Router應(yīng)用方法詳解

 更新時(shí)間:2022年09月20日 11:23:01   作者:??煙花易冷???  
在看這篇文章的幾點(diǎn)要求:需要你先知道Vue-Router是個(gè)什么東西,用來(lái)解決什么問(wèn)題,以及它的基本使用。如果你還不懂的話,建議上官網(wǎng)了解下Vue-Router的基本使用后再回來(lái)看這篇文章

服務(wù)端路由

服務(wù)端路由時(shí)指的是服務(wù)器根據(jù)用戶訪問(wèn)的 URL 路徑返回不同的響應(yīng)結(jié)果。

在傳統(tǒng)的服務(wù)端渲染的 web 應(yīng)用中點(diǎn)擊一個(gè)鏈接時(shí),瀏覽器會(huì)從服務(wù)端獲得全新的 HTML頁(yè)面,然后重新加載整個(gè)頁(yè)面。

然而,在單頁(yè)面應(yīng)用中,客戶端的 JavaScript 可以攔截頁(yè)面的跳轉(zhuǎn)請(qǐng)求,動(dòng)態(tài)獲取新的數(shù)據(jù),無(wú)需重新加載的情況下更新當(dāng)前頁(yè)面。

這樣通常可以帶來(lái)更順滑的用戶體驗(yàn),尤其是在更偏向“應(yīng)用”的場(chǎng)景下,因?yàn)檫@類場(chǎng)景下用戶通常會(huì)在很長(zhǎng)的一段時(shí)間中做出多次交互。

在這類單頁(yè)應(yīng)用中,“路由”是在客戶端執(zhí)行的。一個(gè)客戶端路由器的職責(zé)就是利用諸如 History API 或是 hashchange 事件這樣的瀏覽器 API 來(lái)管理應(yīng)用當(dāng)前應(yīng)該渲染的視圖。

路由的應(yīng)用場(chǎng)景

單頁(yè)面應(yīng)用(SPA應(yīng)用):

  1. 顧名思義導(dǎo)航欄不變,內(nèi)容欄改變的應(yīng)用。
  2. 內(nèi)容欄根據(jù)導(dǎo)航欄的選擇變化的同時(shí),頁(yè)面不會(huì)跳轉(zhuǎn),也就是說(shuō)不會(huì)產(chǎn)生新的請(qǐng)求。
  3. js攔截頁(yè)面的跳轉(zhuǎn)請(qǐng)求,動(dòng)態(tài)的獲取新的數(shù)據(jù),路徑也會(huì)隨之變化。
  4. 數(shù)據(jù)需要通過(guò)ajax的請(qǐng)求獲取。

路由

  1. 路由就是多個(gè)key-value的對(duì)應(yīng)關(guān)系。
  2. 每一個(gè)路由都需要路由器的支持。

監(jiān)聽(tīng)瀏覽器 hashchange 事件實(shí)現(xiàn)路由

如果你只需要一個(gè)簡(jiǎn)單的頁(yè)面路由,而不想為此引入一整個(gè)路由庫(kù),你可以通過(guò)動(dòng)態(tài)組件的方式,監(jiān)聽(tīng)瀏覽器 hashchange 事件或使用 History API 來(lái)更新當(dāng)前組件。

<script>
import About from "./components/About.vue";
import Home from "./components/Home.vue";
import NotFound from "./components/Not Found.vue";
const routes = {
  //路由默認(rèn)跳轉(zhuǎn)到Home組件
  '/': Home,
  '/about': About
}
export default {
  data() {
    return {
      currentPath: window.location.hash
    }
  },
  computed: {
    //計(jì)算屬性的方法,響應(yīng)式的,緩存
    currentView() {
      //過(guò)濾#,匹配路由
      return routes[this.currentPath.slice(1) || '/' ] || NotFound
    }
  },
  mounted() {
    window.addEventListener('hashchange', () => {
      //只要window變化了就,把當(dāng)前的路徑給App組件下的屬性this.currentPath
      this.currentPath = window.location.hash
    })
  }
}
</script>
<template>
  <a href="#/" rel="external nofollow" >Home</a> |
  <a href="#/about" rel="external nofollow" >About</a> |
  <a href="#/non-existent-path" rel="external nofollow" >Broken Link</a>
  <br>
  <component :is="currentView" />
</template>

使用Vue Router+Vue2實(shí)現(xiàn)路由

用 Vue + Vue Router 創(chuàng)建單頁(yè)應(yīng)用非常簡(jiǎn)單:通過(guò) Vue.js,我們已經(jīng)用組件組成了我們的應(yīng)用。當(dāng)加入 Vue Router 時(shí),我們需要做的就是將我們的組件映射到路由上,讓 Vue Router 知道在哪里渲染它們。

1.安裝路由

npm i vue-router@3

注意:

  1. vue3對(duì)應(yīng)的vue-router版本是4
  2. vue2對(duì)應(yīng)的vue-router版本是3
  3. 我這里是vue2

2.導(dǎo)入VueRouter插件(main.js)

import Vue from 'vue'
import App from './App.vue'
import VueRouter from "vue-router"
import './assets/main.css'
//關(guān)閉vue的生產(chǎn)提示
Vue.config.productionTip = false
//使用路由器插件
Vue.use(VueRouter)
new Vue({
  render: (h) => h(App),
}).$mount('#app')

3.編寫創(chuàng)建路由器router(并暴露)的js文件(router/index.js)

import VueRouter from "vue-router";
import Home from "../components/Home";
import About from "../components/About";
import NotFound from "../components/Not Found";
//創(chuàng)建路由器并暴露
export default new VueRouter({
    //多個(gè)路由
    routes:[
        {
            path:'/about',
            component:About
        },
        {
            path:'/Home',
            component:Home
        }
    ]
})

4.引入router(main.js)

import router from "./router";
new Vue({
  render: (h) => h(App),
  router:router
}).$mount('#app')

5. 測(cè)試

<template>
<div>
  <h1>Router Demo</h1>
  <router-link to="/home">Home</router-link>||
  <router-link to="/about">About</router-link>
  <router-view></router-view>
</div>
</template>

Vue3 + Vue-router

到此這篇關(guān)于Vue Router應(yīng)用方法詳解的文章就介紹到這了,更多相關(guān)Vue Router內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue中formdata傳值給后臺(tái)時(shí)參數(shù)為空的問(wèn)題

    vue中formdata傳值給后臺(tái)時(shí)參數(shù)為空的問(wèn)題

    這篇文章主要介紹了vue中formdata傳值給后臺(tái)時(shí)參數(shù)為空的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Vue3中pinia的使用與持久化處理詳解

    Vue3中pinia的使用與持久化處理詳解

    Pinia?是一個(gè)基于?Vue?3?的狀態(tài)管理庫(kù),可以更好地支持?TypeScript?和更靈活的狀態(tài)管理方式,本文主要介紹了pinia的使用與持久化處理,需要的可以參考一下
    2023-07-07
  • vue2.0開發(fā)入門筆記之.vue文件的生成和使用

    vue2.0開發(fā)入門筆記之.vue文件的生成和使用

    本篇文章主要介紹了vue2.0開發(fā)入門筆記之.vue文件的生成和使用 ,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2017-09-09
  • vue3 template轉(zhuǎn)為render函數(shù)過(guò)程詳解

    vue3 template轉(zhuǎn)為render函數(shù)過(guò)程詳解

    在 Vue 中,template 模板是我們編寫組件的主要方式之一,而 Vue 內(nèi)部會(huì)將這些模板轉(zhuǎn)換為 render 函數(shù),render 函數(shù)是用于創(chuàng)建虛擬 DOM 的函數(shù),通過(guò)它,Vue 能夠高效地追蹤 DOM 的變化并進(jìn)行更新,下面我會(huì)通俗易懂地詳細(xì)解釋 Vue 如何將 template 轉(zhuǎn)換為 render 函數(shù)
    2024-10-10
  • vue中v-for加載本地靜態(tài)圖片方法

    vue中v-for加載本地靜態(tài)圖片方法

    下面小編就為大家分享一篇vue中v-for加載本地靜態(tài)圖片方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • Vue與compressor.js實(shí)現(xiàn)高效文件壓縮的方法

    Vue與compressor.js實(shí)現(xiàn)高效文件壓縮的方法

    本文將介紹基于 Vue 框架和 compressor.js 的上傳時(shí)文件壓縮實(shí)現(xiàn)方法,通過(guò)在上傳過(guò)程中對(duì)文件進(jìn)行壓縮,減小文件大小,提升上傳速度,為用戶創(chuàng)造更快捷、高效的上傳體驗(yàn),感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • Vue.js中的全局錯(cuò)誤處理函數(shù)errorHandler用法

    Vue.js中的全局錯(cuò)誤處理函數(shù)errorHandler用法

    這篇文章主要介紹了Vue.js中的全局錯(cuò)誤處理函數(shù)errorHandler用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • 在 Vue-CLI 中引入 simple-mock實(shí)現(xiàn)簡(jiǎn)易的 API Mock 接口數(shù)據(jù)模擬

    在 Vue-CLI 中引入 simple-mock實(shí)現(xiàn)簡(jiǎn)易的 API Mock 接口數(shù)據(jù)模擬

    本文以 Vue-CLI 為例介紹引入 simple-mock 實(shí)現(xiàn)前端開發(fā)數(shù)據(jù)模擬的步驟。感興趣的朋友跟隨小編一起看看吧
    2018-11-11
  • Vue引入sign-canvas實(shí)現(xiàn)簽名畫板效果

    Vue引入sign-canvas實(shí)現(xiàn)簽名畫板效果

    這篇文章主要介紹了Vue引入sign-canvas實(shí)現(xiàn)簽名畫板,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • Vue中事件總線(eventBus)的深入詳解及使用

    Vue中事件總線(eventBus)的深入詳解及使用

    在vue項(xiàng)目中父子組件間的通訊很方便,但兄弟組件或多層嵌套組件間的通訊,就會(huì)比較麻煩,這時(shí)使用eventBus通訊,就可以很便捷的解決這個(gè)問(wèn)題,這篇文章主要給大家介紹了關(guān)于Vue中事件總線(eventBus)使用的相關(guān)資料,需要的朋友可以參考下
    2022-03-03

最新評(píng)論