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

vue中實(shí)現(xiàn)路由跳轉(zhuǎn)的三種方式超詳細(xì)教程

 更新時(shí)間:2022年11月21日 09:28:57   作者:殿君不是殿軍  
這篇文章主要介紹了vue中實(shí)現(xiàn)路由跳轉(zhuǎn)的三種方式超詳細(xì)教程,其中聲明式router-link實(shí)現(xiàn)跳轉(zhuǎn)最簡(jiǎn)單的方法,可用組件router-link來(lái)替代a標(biāo)簽,每種方式給大家講解的非常詳細(xì)需要的朋友可以參考下

vue中實(shí)現(xiàn)路由跳轉(zhuǎn)的三種方式

一、使用vue-router

vue-router 本質(zhì)是一個(gè)第三方的包 用的時(shí)候需要下載

步驟 (7步法 ):

下載vue-router模塊到當(dāng)前工程

 yarn add vue-router

在main.js中引入VueRouter函數(shù)

// 引入路由
import VueRouter from "vue-router";

添加到Vue.use()身上 – 注冊(cè)全局RouterLink和RouterView組件

// 注冊(cè)全局
Vue.use(VueRouter)

創(chuàng)建路由規(guī)則數(shù)組 – 路徑和組件名對(duì)應(yīng)關(guān)系

創(chuàng)建路由規(guī)則數(shù)組(需要準(zhǔn)備切換的頁(yè)面組件)把準(zhǔn)備好的頁(yè)面組件引入到main.js中

const routes = [{
            path: "/",
            redirect: "find" //默認(rèn)顯示推薦組件(路由的重定向)
        },
        {
            path: "/find",
            name: "Find",
            component: Find,
            //二級(jí)路由
            children: [{
                    path: "/",
                    redirect: "recom" //默認(rèn)顯示推薦組件
                },
                {
                    path: "ranking", //注意二級(jí)路由的路徑千萬(wàn)不要加/
                    component: Ranking
                },
                {
                    path: "songlist",
                    component: SongList
                },
            ]
        },
        {
            path: "/my",
            name: "My",
            component: My
        },
        {
            path: "/part",
            name: "Part",
            component: Part
        },

        {
            path: "*",
            component: NotFound //定義找不到已有組件時(shí)顯示404
        },
    ]

用規(guī)則生成路由對(duì)象

    // 創(chuàng)建路由對(duì)象并且傳入規(guī)則
const router = new VueRouter({
    routes,
    mode: "history" //路由模式(默認(rèn)為hash模式)
})

把路由對(duì)象注入到new Vue實(shí)例中

new Vue({
    router, //導(dǎo)入路由對(duì)象
    render: h => h(App),
}).$mount('#app')

router-view作為掛載點(diǎn), 切換不同的路由頁(yè)面

當(dāng)url的hash值路徑切換,顯示規(guī)則里對(duì)應(yīng)的組件

router-view 實(shí)現(xiàn)路由內(nèi)容的地方,引入組件時(shí)寫(xiě)到需要引入的地方 需要注意的是,使用vue-router控制路由則必須router-view作為容器。(可以先引入根組件App.vue中進(jìn)行自測(cè))

注意: 一切都要以u(píng)rl上hash值為準(zhǔn)

二、聲明式-router-link 【實(shí)現(xiàn)跳轉(zhuǎn)最簡(jiǎn)單的方法】

1.可用組件router-link來(lái)替代a標(biāo)簽

  • router-link 是vue-router提供了一個(gè)全局組件
  • router-link實(shí)質(zhì)上最終會(huì)渲染成a鏈接 to屬性等價(jià)于提供 href屬性(to無(wú)需#)
  • router-link提供了聲明式導(dǎo)航高亮的功能(自帶類(lèi)名)

代碼如下:

<template>
  <div>
    <div class="footer_wrap">
      <router-link to="/find">發(fā)現(xiàn)音樂(lè)</router-link>
      <router-link to="/my">我的音樂(lè)</router-link>
      <router-link to="/part">朋友</router-link>
    </div>
    <div class="top">
      <router-view></router-view>
    </div>
  </div>
</template>
//在控制臺(tái)元素檢查時(shí)會(huì)發(fā)現(xiàn)激活的類(lèi)名 在樣式style中定義高亮樣式 點(diǎn)擊時(shí)就會(huì)高亮

router-link好處 : 自帶激活時(shí)的類(lèi)名, 可以做高亮

2.在跳轉(zhuǎn)路由時(shí), 可以給路由對(duì)應(yīng)的組件內(nèi)傳值

在router-link上的to屬性傳值, 語(yǔ)法格式如下 :

(方式一)

to=/path?參數(shù)名=值

例:to="/part?name=小明"

對(duì)應(yīng)頁(yè)面組件接收傳遞過(guò)來(lái)的值

$route.query.參數(shù)名

接收數(shù)據(jù):$route.query.name

(方式二)

to=“/path/值” (需在路由規(guī)則里配置/path/:參數(shù)名)

例:to="/part/小王"

配置:path:"/part/:username"

對(duì)應(yīng)頁(yè)面組件接收傳遞過(guò)來(lái)的值 (注意動(dòng)態(tài)參數(shù)需要用params接收)

$route.params.參數(shù)名

接收數(shù)據(jù):$route.params.username

三、編程式-用JS代碼來(lái)進(jìn)行跳轉(zhuǎn)

用JS代碼來(lái)進(jìn)行跳轉(zhuǎn)

語(yǔ)法: path或者name任選一個(gè)

一、$ router $ route的區(qū)別

$router : 是路由操作對(duì)象,只寫(xiě)對(duì)象

$route : 路由信息對(duì)象,只讀對(duì)象

$ router操作路由跳轉(zhuǎn)

this.$router.push({ name:‘hello', query:{ name:‘word', age:‘11' } })

$route讀取 路由參數(shù)接收

var name = this.$route.query.name;

二、路由跳轉(zhuǎn)方式name 、 path 和傳參方式params 、query的區(qū)別(重要)

path 和 name路由跳轉(zhuǎn)方式,都可以用query傳參

使用path方式跳轉(zhuǎn)路由 path會(huì)忽略params 所以path不能和params一起使用
推薦使用name和query方式實(shí)現(xiàn)路由跳轉(zhuǎn)

params傳參,push里面只能是 name:‘xxx’,不能是path:‘/xxx’,因?yàn)閜arams只能用name來(lái)引入路由,如果這里寫(xiě)成了path,接收參數(shù)頁(yè)面會(huì)是undefined?。?!

通過(guò)params傳參

==注意:==這里使用name路由跳轉(zhuǎn)方式路徑不需要加 / 因?yàn)樗皇莻€(gè)名字

this.$router.push({
    name:"Home",
    params:{
        id:this.id
    }
})

另一個(gè)頁(yè)面接收:

這里使用params傳參就需要寫(xiě)params接收

this.$route.params.id

通過(guò)query傳參

this.$router.push({
    path:"/Search",
    query:{ //query是個(gè)配置項(xiàng)
        age:20
    }
})

另一個(gè)頁(yè)面接收

this.$route.query.age

query相當(dāng)于GET請(qǐng)求,頁(yè)面跳轉(zhuǎn)的時(shí)候,可以在地址欄看到請(qǐng)求參數(shù)

uery傳參**

this.$router.push({
    path:"/Search",
    query:{ //query是個(gè)配置項(xiàng)
        age:20
    }
})

另一個(gè)頁(yè)面接收

this.$route.query.age

總結(jié):
query相當(dāng)于GET請(qǐng)求,頁(yè)面跳轉(zhuǎn)的時(shí)候,可以在地址欄看到請(qǐng)求參數(shù)

params相當(dāng)于POST請(qǐng)求,參數(shù)不會(huì)在地址欄中顯示

到此這篇關(guān)于vue中實(shí)現(xiàn)路由跳轉(zhuǎn)的三種方式超詳細(xì)教程的文章就介紹到這了,更多相關(guān)vue路由跳轉(zhuǎn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vuejs第七篇之Vuejs過(guò)渡動(dòng)畫(huà)案例全面解析

    Vuejs第七篇之Vuejs過(guò)渡動(dòng)畫(huà)案例全面解析

    這篇文章主要介紹了Vuejs第七篇之Vuejs過(guò)渡動(dòng)畫(huà)案例全面解析的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • vue生命周期和react生命周期對(duì)比【推薦】

    vue生命周期和react生命周期對(duì)比【推薦】

    本文通過(guò)實(shí)例代碼給大家介紹了vue生命周期和react生命周期對(duì)比 ,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-09-09
  • Vue默認(rèn)插槽,具名插槽,作用域插槽定義及使用方法

    Vue默認(rèn)插槽,具名插槽,作用域插槽定義及使用方法

    這篇文章主要介紹了Vue默認(rèn)插槽,具名插槽,作用域插槽定義及使用方法,插槽的作用是在子組件中某個(gè)位置插入父組件的自定義html結(jié)構(gòu)和data數(shù)據(jù),下面詳細(xì)內(nèi)容需要的小伙伴可以參考一下
    2022-03-03
  • 全面總結(jié)Vue3.0的多種偵聽(tīng)方式

    全面總結(jié)Vue3.0的多種偵聽(tīng)方式

    Vue提供了一種更通用的方式來(lái)觀察和響應(yīng)當(dāng)前活動(dòng)的實(shí)例上的數(shù)據(jù)變動(dòng):偵聽(tīng)屬性,下面這篇文章主要給大家介紹了關(guān)于Vue3.0多種偵聽(tīng)方式的相關(guān)資料,需要的朋友可以參考下
    2021-10-10
  • Element-plus封裝搜索組件的實(shí)現(xiàn)

    Element-plus封裝搜索組件的實(shí)現(xiàn)

    在后臺(tái)管理系統(tǒng)中,經(jīng)常需要在多個(gè)頁(yè)面中使用搜索功能,本文就來(lái)介紹一下Element-plus封裝搜索組件的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-08-08
  • Vue3學(xué)習(xí)之表單的使用示例詳解

    Vue3學(xué)習(xí)之表單的使用示例詳解

    這篇文章主要為大家詳細(xì)介紹了Vue3中表單的使用的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),對(duì)我們掌握Vue3有一定的幫助,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2022-12-12
  • Vue2中無(wú)法檢測(cè)到數(shù)組變動(dòng)的原因及解決

    Vue2中無(wú)法檢測(cè)到數(shù)組變動(dòng)的原因及解決

    由于某些限制,vue2不能檢測(cè)到某些情況下數(shù)組的變動(dòng),本文就將具體講解這兩種限制的解決思路
    2021-06-06
  • 如何將百度地圖包裝成Vue的組件的方法步驟

    如何將百度地圖包裝成Vue的組件的方法步驟

    這篇文章主要介紹了如何將百度地圖包裝成Vue的組件的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-02-02
  • Vue狀態(tài)管理庫(kù)Vuex的入門(mén)使用教程

    Vue狀態(tài)管理庫(kù)Vuex的入門(mén)使用教程

    Vuex是一個(gè)專(zhuān)門(mén)為Vue.js應(yīng)用程序開(kāi)發(fā)的狀態(tài)管理庫(kù)。它采用了一個(gè)集中式的架構(gòu),將應(yīng)用程序的所有組件的狀態(tài)存儲(chǔ)在一個(gè)單獨(dú)的地方。這使得狀態(tài)的管理和維護(hù)變得更加容易
    2023-03-03
  • 解決vuecli3中img src 的引入問(wèn)題

    解決vuecli3中img src 的引入問(wèn)題

    這篇文章主要介紹了解決vuecli3中img src 的引入問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08

最新評(píng)論