十年網(wǎng)站開發(fā)經(jīng)驗 + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊
量身定制 + 運營維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
小編給大家分享一下vue中$router和$route及router與 router與route區(qū)別有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
站在用戶的角度思考問題,與客戶深入溝通,找到沅陵網(wǎng)站設(shè)計與沅陵網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都做網(wǎng)站、網(wǎng)站建設(shè)、外貿(mào)營銷網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名注冊、虛擬空間、企業(yè)郵箱。業(yè)務(wù)覆蓋沅陵地區(qū)。
1 this.$router和this.$route的區(qū)別
vue router
this.$router
是VueRouter的實例方法,當(dāng)導(dǎo)航到不同url,可以使用this.$router.push
方法,這個方法則會向history里面添加一條記錄,當(dāng)點擊瀏覽器回退按鈕或者this.$router.back()
就會回退之前的url。this.$route
相當(dāng)于當(dāng)前激活的路由對象,包含當(dāng)前url解析得到的數(shù)據(jù),可以從對象里獲取一些數(shù)據(jù),如name,path等。
2 路由跳轉(zhuǎn)分為編程式和聲明式
聲明式
//路由入口//視圖出口 //路由入口 //視圖出口
當(dāng)你想在一個頁面嵌套子路由,并且不跳轉(zhuǎn)頁面的時候,我覺得這個超好用啊,子頁面就會渲染在router-view的地方
編程式
// 字符串 router.push('home') // 對象 router.push({ path: 'home' }) // 命名的路由 router.push({ name: 'user', params: { userId: '123' }}) // 帶查詢參數(shù),變成 /register?plan=private router.push({ path: 'register', query: { plan: 'private' }}) // 字符串 router.push('home') // 對象 router.push({ path: 'home' }) // 命名的路由 router.push({ name: 'user', params: { userId: '123' }}) // 帶查詢參數(shù),變成 /register?plan=private router.push({ path: 'register', query: { plan: 'private' }})
但是一定要注意啊,如果你提供了path,那么params和query的配置就會被忽略的
3 path:'name'和path:'/name'的區(qū)別
如果加/則會被當(dāng)作跟目錄,否則當(dāng)前的路徑會嵌套在之前的路徑中
//比如當(dāng)前路徑是home this.$router.push({path:'name'})//==>path為/home/name this.$router.push({path:'/name'})//==>path為/name //比如當(dāng)前路徑是home this.$router.push({path:'name'})//==>path為/home/name this.$router.push({path:'/name'})//==>path為/name
ps:下面看下vue中router與 router與route區(qū)別
vue-router中經(jīng)常會操作的兩個對象route和 route和router兩個。
1、$route對象
$route對象表示當(dāng)前的路由信息,包含了當(dāng)前 URL 解析得到的信息。包含當(dāng)前的路徑,參數(shù),query對象等。
**1.$route.path**
字符串,對應(yīng)當(dāng)前路由的路徑,總是解析為絕對路徑,如 "/foo/bar"。
**2.$route.params**
一個 key/value 對象,包含了 動態(tài)片段 和 全匹配片段,
如果沒有路由參數(shù),就是一個空對象。
**3.$route.query**
一個 key/value 對象,表示 URL 查詢參數(shù)。
例如,對于路徑 /foo?user=1,則有 $route.query.user == 1,
如果沒有查詢參數(shù),則是個空對象。
**4.$route.hash**
當(dāng)前路由的 hash 值 (不帶 #) ,如果沒有 hash 值,則為空字符串。錨點
**5.$route.fullPath**
完成解析后的 URL,包含查詢參數(shù)和 hash 的完整路徑。
**6.$route.matched**
數(shù)組,包含當(dāng)前匹配的路徑中所包含的所有片段所對應(yīng)的配置參數(shù)對象。
**7.$route.name 當(dāng)前路徑名字**
**8.$route.meta 路由元信息
route object 出現(xiàn)在多個地方:
?組件內(nèi)的 this.route和 route和route watcher 回調(diào)(監(jiān)測變化處理);
?router.match(location) 的返回值
?scrollBehavior 方法的參數(shù)
?導(dǎo)航鉤子的參數(shù):
router.beforeEach((to, from, next) => { // to 和 from 都是 路由信息對象,后面使用路由的鉤子函數(shù)就容易理解了 })
2、$router對象
$router對象是全局路由的實例,是router構(gòu)造方法的實例。
路由實例方法:
1、push
// 字符串 this.$router.push('home') // 對象 this.$router.push({ path: 'home' }) // 命名的路由 this.$router.push({ name: 'user', params: { userId: 123 }}) // 帶查詢參數(shù),變成 /register?plan=123 this.$router.push({ path: 'register', query: { plan: '123' }})
push方法其實和
是等同的。
注意:push方法的跳轉(zhuǎn)會向 history 棧添加一個新的記錄,當(dāng)我們點擊瀏覽器的返回按鈕時可以看到之前的頁面。
2、go
// 頁面路由跳轉(zhuǎn) 前進(jìn)或者后退 this.$router.go(-1) // 后退
3、replace
//push方法會向 history 棧添加一個新的記錄,而replace方法是替換當(dāng)前的頁面, 不會向 history 棧添加一個新的記錄
05
// 一般使用replace來做404頁面 this.$router.replace('/')
配置路由時path有時候會加 '/' 有時候不加,以'/'開頭的會被當(dāng)作根路徑,就不會一直嵌套之前的路徑。
以上是“vue中$router和$route及router與 router與route區(qū)別有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!