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

詳解Vue-Router的安裝與使用

 更新時間:2021年06月21日 08:37:52   作者:性感的小肥貓  
Vue Router 是 Vue.js 官方的路由管理器。它和 Vue.js 的核心深度集成,讓構(gòu)建單頁面應(yīng)用變得易如反掌。本文介紹下Vue Router的安裝與使用

安裝

1.在已有Vue項目中手動安裝vue-router

npm install --save vue-router

2.使用vue-cli創(chuàng)建自帶vue-router的新項目
空格選擇/取消 a全選 i反選

vue create project_name
#Vue 會詢問你使用哪種配置
Default ([Vue 2] babel, eslint)
Default (Vue 3 Preview) ([Vue 3] babel, eslint)
Manually select features 

#請選擇 Manually select features,Vue會詢問你當(dāng)前項目需要哪些配置

Check the features needed for your project: (Press <space> to select, <a> to toggle all, <i> to invert selection)

>(*) Choose Vue version
(*) Babel
( ) TypeScript
( ) Progressive Web App (PWA) Support
( ) Router
( ) Vuex
( ) CSS Pre-processors
(*) Linter / Formatter
( ) Unit Testing
( ) E2E Testing   
#請將Router 選中,后面一系列的詢問按照實際情況進(jìn)行選擇就好

路由的基礎(chǔ)配置

  1. 如果選擇了第一種安裝方式(手動安裝),需要手動在src文件夾下新建一個名為router的文件夾并新建index.js文件
  2. 如果選擇了第二種安裝方式(自定義安裝),不用自己進(jìn)行配置,新建項目完畢后就可以直接使用了

將Router安裝到Vue中

如果需要讓當(dāng)前Vue實例支持路由功能.需要在Vue實例化時將VueRouter的實例對象注入到Vue實例配置選項router中。(手動安裝)

// src/router/index.js

import Vue from 'vue' // 引入Vue
import VueRouter from 'vue-router' // 引入VueRouter

// Vue支持VueRouter
Vue.use(VueRouter)

let router = new VueRouter() // 初始化VueRouter

new Vue({  
  router // 將VueRouter的實例對象配置到Vue實例化配置對象的router選項中
}).$mount('#app')

main.js中引用

// src/main.js

import router from './router'

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

Router的相關(guān)配置

屬性名 類型 描述
routes Array 當(dāng)前Router中所有路由配置
modeString 可選值: "hash" / "history" 默認(rèn)值'hash' 該模式下路由使用hash保證路由與視圖一致history 模式使用h5新增 window.history 實現(xiàn)路由與視圖一致
linkActiveClass String 默認(rèn)值: "router-link-active" 全局配置  默認(rèn)的激活的 class
linkExactActiveClass String 默認(rèn)值: "router-link-exact-active" 全局配置  默認(rèn)的精確激活的 class。

注意 嚴(yán)格匹配link標(biāo)簽to路由路徑必須全等于當(dāng)前瀏覽器的url,非嚴(yán)格匹配當(dāng)前瀏覽器url可以為當(dāng)前l(fā)ink的子路由。

例子

to="/home"   url="/home/user" 非嚴(yán)格匹配
to="/home"   url="/home/user/10086" 非嚴(yán)格匹配
to="/home"   url="/home"  嚴(yán)格匹配
to="/"       url="/order" / 是所有路由的根路由,所以他們非嚴(yán)格匹配

Router.routes 的相關(guān)配置

{
  path: string,
  component?: Component, // 當(dāng)前路由匹配時顯示的路由組件
  name?: string, // 命名路由
  redirect?: string | Location | Function, // 路由重定向
  props?: boolean | Object | Function,  // 
  alias?: string | Array<string>, // 路由別名
  children?: Array<RouteConfig>, // 嵌套路由
  beforeEnter?: (to: Route, from: Route, next: Function) => void, //路由守衛(wèi)
  caseSensitive?: boolean, // 匹配規(guī)則是否大小寫敏感?(默認(rèn)值:false)
}

實現(xiàn)一個簡單的路由

1.配置路由

import Vue from 'vue'
import VueRouter from 'vue-router'
import App from './App.vue'
import Home from './views/Home'
import Order from './views/Order'
import User from './views/User'

// Vue支持VueRouter
Vue.use(VueRouter)

let router = new VueRouter({
  routes: [
    {
      path: '/home',
      component: Home
    },
    {
      path: '/order',
      component: Order
    },
    {
      path: '/user',
      component: User
    }
  ]
})

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

2. 在組件中實現(xiàn)路由

VueRouter給Vue提供了兩個組件

  • router-link
  • router-view

1. router-link 用于實現(xiàn)路由的跳轉(zhuǎn)組件:該組件支持的屬性

to: string | location 當(dāng)用戶點擊該組件時就會跳轉(zhuǎn)至to指定的路由

// 導(dǎo)航指定的url
<router-link to="/home">主頁</router-link>
<router-link to="/order">訂單</router-link>
<router-link to="/user">用戶</router-link>
/* 導(dǎo)航指定的location
vue router中l(wèi)ocation對象的常用屬性{
    path:'/', //指定跳轉(zhuǎn)路由的路徑
    hash:'#top' // 指定跳轉(zhuǎn)路由的哈希值 
    name: 'Home', // 指定跳轉(zhuǎn)的具名路由的name值
    params: {}, // 指定跳轉(zhuǎn)的路由傳遞params對象
    query: {} //  指定跳轉(zhuǎn)的路由傳遞query鍵值對
}
*/
<router-link :to="{path:'/user'}">user</router-link>
// 使用location進(jìn)行頁面跳轉(zhuǎn)時,當(dāng)前l(fā)ocation的params屬性無法傳遞給路由組件的
<router-link :to="{path:'/user',hash:'#top',params:{id:1,name:'小明'}}">user</router-link>
// 使用name路由導(dǎo)航,可以向任何具名路由傳遞params
<router-link :to="{name:'User',hash:'#top',params:{id:1,name:'小明'}}">user</router-link>
// query支持 name導(dǎo)航和path導(dǎo)航,不推薦傳遞對象屬性時使用query傳參
<router-link :to="{name:'User',hash:'#top',query:{id:1,name:'小明'}}">user</router-link>

replace: bool 當(dāng)該屬性為真時,路由的跳轉(zhuǎn)將以替換的形式跳轉(zhuǎn)到下一個頁面(下一個路由會把當(dāng)前瀏覽器歷史記錄棧中的url替換成將要跳轉(zhuǎn)的路由),默認(rèn)值為false

// 使用替換的形式跳轉(zhuǎn)路由
<router-link class="tab-item" replace to="/user">用戶</router-link>

append: bool 當(dāng)該屬性為真時,當(dāng)前路由如果是相對路徑(路徑?jīng)]有/開頭)路由的跳轉(zhuǎn)將會基于瀏覽器url進(jìn)行下一級的跳轉(zhuǎn),默認(rèn)值為false

// 如果當(dāng)前瀏覽器url /order
// 點擊 Gec 會跳轉(zhuǎn)到 /order/gec
<router-link  to="gec" append>Gec</router-link>
// 點擊 Gec1 因為Gec1的to不是相對路徑 append就會無效,路由會跳轉(zhuǎn)到 /gec
<router-link  to="/gec" append>Gec1</router-link>
// 點擊 Gec2 沒有append 會跳轉(zhuǎn)到 /gec
<router-link  to="gec">Gec2</router-link>

tag: string 指定當(dāng)該router-link標(biāo)簽最終以什么DOM元素渲染到頁面上,默認(rèn)值是a

// 將router-link以span元素渲染到頁面上
<router-link tag="span" class="tab-item" to="/">主頁</router-link>

active-class: string 指定當(dāng)前router-link元素,如果與瀏覽器url非嚴(yán)格匹配時class名。默認(rèn)值是VueRouter實例化時 linkActiveClass 指定值

// 當(dāng)前router-link非嚴(yán)格匹配時class名為aaaa
<router-link  active-class="aaaa" to="/order">訂單</router-link>

event: string | Array<string> 指定當(dāng)前router-link元素,聲明可以用來觸發(fā)導(dǎo)航的事件。可以是一個字符串或是一個包含字符串的數(shù)組。默認(rèn)值是click

// 雙擊 和 點擊都能觸發(fā)當(dāng)前元素的路由跳轉(zhuǎn)
<router-link :event="['dblclick','click']"  to="/">主頁</router-link>

2. router-view 根據(jù)當(dāng)前VueRouter的配置,當(dāng)路由路由路徑發(fā)生改變時渲染對應(yīng)的路由視圖組件

router-view 組件是一個 functional 組件,渲染路徑匹配到的視圖組件。 渲染的組件還可以內(nèi)嵌自己的 router-view,根據(jù)嵌套路徑,渲染嵌套組件。 其他屬性 (非 router-view 使用的屬性除name) 都直接傳給渲染的組件,很多時候,每個路由的數(shù)據(jù)都是包含在路由參數(shù)中。

因為它也是個組件,所以可以配合 transition 和 keep-alive 使用。如果兩個結(jié)合一起用,要確保在內(nèi)層使用 keep-alive:

<transition name="fade">
  <keep-alive>
    <router-view></router-view>
  </keep-alive>
</transition>

以上就是詳解Vue-Router的安裝與使用的詳細(xì)內(nèi)容,更多關(guān)于Vue-Router的安裝與使用的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vuex中store.commit和store.dispatch的區(qū)別及使用方法

    vuex中store.commit和store.dispatch的區(qū)別及使用方法

    這篇文章主要介紹了vuex中store.commit和store.dispatch的區(qū)別及使用方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • bpmn-js在vue中的基本使用及操作功能

    bpmn-js在vue中的基本使用及操作功能

    這篇文章主要介紹了bpmn-js在vue中的基本使用及操作功能,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友跟隨小編一起看看吧
    2024-02-02
  • vue項目優(yōu)雅實現(xiàn)自動引入組件的方法詳解

    vue項目優(yōu)雅實現(xiàn)自動引入組件的方法詳解

    在我們寫vue項目的時候,都會引入一些組件庫,有時候有可能還不止一個組件庫,那么如何優(yōu)雅的實現(xiàn)自動引入組件呢,下面小編就來和大家詳細(xì)講講吧
    2023-09-09
  • Vue跨端渲染實現(xiàn)多端無縫銜接

    Vue跨端渲染實現(xiàn)多端無縫銜接

    這篇文章主要介紹了Vue跨端渲染實現(xiàn)多端無縫銜接,Vue跨端渲染是一種基于Vue框架的跨平臺開發(fā)技術(shù),能夠?qū)崿F(xiàn)Web、iOS和Android三端的無縫銜接,提高開發(fā)效率和用戶體驗
    2023-05-05
  • 關(guān)于Vue Router中路由守衛(wèi)的應(yīng)用及在全局導(dǎo)航守衛(wèi)中檢查元字段的方法

    關(guān)于Vue Router中路由守衛(wèi)的應(yīng)用及在全局導(dǎo)航守衛(wèi)中檢查元字段的方法

    這篇文章主要介紹了關(guān)于Vue Router中路由守衛(wèi)的應(yīng)用及在全局導(dǎo)航守衛(wèi)中檢查元字段的方法,實現(xiàn)方法有兩種,本文通過實例代碼對每種方法介紹的很詳細(xì),需要的朋友參考下
    2018-12-12
  • 詳解Vue依賴收集引發(fā)的問題

    詳解Vue依賴收集引發(fā)的問題

    這篇文章主要介紹了Vue依賴收集引發(fā)的問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • vue3 emit is not a function問題及解決

    vue3 emit is not a function問題及解決

    這篇文章主要介紹了vue3 emit is not a function問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-09-09
  • element日歷calendar組件上月、今天、下月、日歷塊點擊事件及模板源碼

    element日歷calendar組件上月、今天、下月、日歷塊點擊事件及模板源碼

    這篇文章主要介紹了element日歷calendar組件上月、今天、下月、日歷塊點擊事件及模板源碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 從vue源碼看props的用法

    從vue源碼看props的用法

    平時寫vue的時候知道 props 有很多種用法,今天我們來看看vue內(nèi)部是怎么處理 props 中那么多的用法的。非常具有實用價值,需要的朋友可以參考下
    2019-01-01
  • vue ref如何獲取子組件屬性值

    vue ref如何獲取子組件屬性值

    這篇文章主要介紹了vue ref如何獲取子組件屬性值。具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03

最新評論