亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue-router 2.0 跳轉(zhuǎn)之router.push()用法說(shuō)明

 更新時(shí)間:2020年08月12日 14:30:12   作者:憤怒的小青春  
這篇文章主要介紹了vue-router 2.0 跳轉(zhuǎn)之router.push()用法說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

router.push(location)

除了使用 創(chuàng)建 a 標(biāo)簽來(lái)定義導(dǎo)航鏈接,我們還可以借助 router 的實(shí)例方法,通過(guò)編寫代碼來(lái)實(shí)現(xiàn)。

router.push(location)

想要導(dǎo)航到不同的 URL,則使用 router.push 方法。這個(gè)方法會(huì)向 history 棧添加一個(gè)新的記錄,所以,當(dāng)用戶點(diǎn)擊瀏覽器后退按鈕時(shí),則回到之前的 URL。

當(dāng)你點(diǎn)擊 <router-link> 時(shí),這個(gè)方法會(huì)在內(nèi)部調(diào)用,所以說(shuō),點(diǎn)擊 等同于調(diào)用 router.push(…)。

聲明式:<router-link :to="...">

編程式:router.push(...)

該方法的參數(shù)可以是一個(gè)字符串路徑,或者一個(gè)描述地址的對(duì)象。

// 字符串
router.push('home')

// 對(duì)象
this.$router.push({path: '/login?url=' + this.$route.path});

// 命名的路由
router.push({ name: 'user', params: { userId: 123 }})

// 帶查詢參數(shù),變成/backend/order?selected=2
this.$router.push({path: '/backend/order', query: {selected: "2"}});

// 設(shè)置查詢參數(shù)
this.$http.post('v1/user/select-stage', {stage: stage})
   .then(({data: {code, content}}) => {
      if (code === 0) {
        // 對(duì)象
        this.$router.push({path: '/home'});
      }else if(code === 10){
        // 帶查詢參數(shù),變成/login?stage=stage
        this.$router.push({path: '/login', query:{stage: stage}});
      }
});

// 設(shè)計(jì)查詢參數(shù)對(duì)象
let queryData = {};
if (this.$route.query.stage) {
  queryData.stage = this.$route.query.stage;
}
if (this.$route.query.url) {
  queryData.url = this.$route.query.url;
}
this.$router.push({path: '/my/profile', query: queryData});

replace

類型: boolean

默認(rèn)值: false

設(shè)置 replace 屬性的話,當(dāng)點(diǎn)擊時(shí),會(huì)調(diào)用 router.replace() 而不是 router.push(),于是導(dǎo)航后不會(huì)留下 history 記錄。即使點(diǎn)擊返回按鈕也不會(huì)回到這個(gè)頁(yè)面。

//加上replace: true后,它不會(huì)向 history 添加新記錄,而是跟它的方法名一樣 —— 替換掉當(dāng)前的 history 記錄。

this.$router.push({path: '/home', replace: true})
//如果是聲明式就是像下面這樣寫:
<router-link :to="..." replace></router-link>
// 編程式:
router.replace(...)

綜合案例

this.$router.push({path: '/coach/' + this.$route.params.id, query: queryData});

補(bǔ)充知識(shí):解決從登錄頁(yè)通過(guò)this.$router.push跳轉(zhuǎn)首頁(yè)后 點(diǎn)返回健路由變而頁(yè)面不變的問(wèn)題

做H5項(xiàng)目的時(shí)候遇到一個(gè)問(wèn)題,我從 login 登錄頁(yè)通過(guò) this.$router.push({ name: 'home' })路由登錄成功后跳轉(zhuǎn)到首頁(yè),但在ios系統(tǒng)下,會(huì)有一個(gè)默認(rèn)返回條,點(diǎn)擊返回鍵出現(xiàn)以下情況,路由顯示的是回到登錄頁(yè),而頁(yè)面卻還是首頁(yè)。

解決思路:

開始我試著把push改為replace,但是發(fā)現(xiàn)并沒什么卵用,還是會(huì)出現(xiàn)問(wèn)題,所以只好用路由導(dǎo)航守衛(wèi)去監(jiān)聽。

在首頁(yè)加入beforeRouteLeave,監(jiān)聽到to.name如果是login的話就不跳轉(zhuǎn),否則就跳轉(zhuǎn),然后問(wèn)題就解決了。

beforeRouteLeave (to, from, next) {
  if (to.name === 'login') {
    next(false)// 不跳轉(zhuǎn)
  } else {
    next() // 跳轉(zhuǎn)到另一個(gè)路由
  }
}

以上這篇vue-router 2.0 跳轉(zhuǎn)之router.push()用法說(shuō)明就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論