在vue中,動態路由就是將匹配某種模式下的路由映射到同一個元件中,動態路由的本質就是透過url進行傳參;可以透過「params」和「query」兩種方式來傳遞動態參數。
本文操作環境:windows10系統、Vue2.9.6版,DELL G3電腦。
#動態路由就是把符合某種模式下的路由對應到同一個元件中,其實本質就是透過url進行傳參
比如說:有一個商品Goods的元件,我們需要讓不同的商品id都映射到這個元件中,此時就需要用到動態路由了。
可以透過兩種方式來傳遞動態參數:
(1)、params
(2)、query
注意:以下程式碼的示範都是在history的路由模式下
配置路由的方式:使用冒號:綁定動態參數。
//index.js中配置路由信息 const routes = [{ path: '/goods/:id', component: Goods}]
路由跳轉時,分為:
(1)使用router-link方式實現路由跳轉
此種方式下,一可以使用字串,在路徑後面直接跟上對應的值,如:
二可以使用物件的方式,如:
注意:
//方法1 this.$router.push('/goods/' + this.goodsId) //方法2 this.$router.push({ name: 'goods', params: { id: this.goodsId }})
params方式的傳參,對應傳參後的url位址如下:
取得參數的方式:
$router.params,如本例中想要取得id的值,對應程式碼為:
$route.params.id
配置路由時,普通配置即可,也就是原來怎麼配置路由,現在就還怎麼配置。如:
const routes = [{ path: '/goods', name: 'goods', component: Goods}]
路由跳轉時,分為:
(1)使用router-link方式實現路由跳轉
query傳參的方式只可以透過對象,不可以使用字串
<router-link>商品</router-link>
(2)、使用$router的方式進行路由的跳轉
this.$router.push({ path: '/goods', query: { id: this.goodsId } })
this.$router.push({ path: '/goods', query: { id: this.goodsId } })
query方式的傳參,對應傳參後的url位址顯示為:
# 注意:query方式的傳參,query物件裡面的屬性名(如本例中的id)可以隨便取名,不像params方式傳參時受限。
同時,此種方式下路由的引進既可以使用path屬性,也可以使用name屬性。
取得參數的方式:
$route.query,如本例想要取得id 值,程式碼為:
$route.query.id
總之,千萬要注意:
(1)、 params方式路由的引進只能用name,query方式路由的引進可以用name和path。
(2)、路由跳轉使用 「router」;取得參數使用「route」
【相關推薦:《vue.js教學》】
以上是vue動態路由是什麼意思的詳細內容。更多資訊請關注PHP中文網其他相關文章!