1.在浏览器中,点击链接实现导航的方式,叫做声明式导航,例如:

普通网页中点击<a>链接、vue项目中点击<router-link>都属于声明式导航

2.在浏览器中,调用API方法实现导航的方式,叫做编程式导航,例如:

普通网页中调用location.href跳转到新页面的方式,属于编程式导航

vue-router中的编程式导航API

1.this.$router.push('hash地址')

跳转到指定hash地址,并增加一条历史记录(可后退)

<button @click="gotoLK">跳转到电影1页面</button>
methods: {
  gotoLK(){
    // 通过编程式导航API,导航跳转到指定的页面(可后退)
    this.$router.push('/movie/1')
  },
  },

 

2.this.$router.replace('hash地址')

跳转到指定的hash地址,并替换掉当前的历史纪录

<button @click="gotoLK2">跳转到电影2页面</button>
methods: {
  gotoLK2(){
      // 通过编程式导航API,导航跳转到指定的页面(不可后退)
      this.$router.replace('/movie/2')
  }
  },

3.this.$router.go(数值n)

可在浏览器历史中前进和后退

  <button @click="goBack1">后退</button>
  <button @click="goBack2">前进</button>
  methods:{
  goBack1(){
    // go(-1)后退一层
    this.$router.go(-1)
    // go(-100)如果后退层数超过上限,则原地不动
  this.$router.go(-100)
  },
  goBack2(){
      this.$router.go(1)
  }
}

$router.go的简化方法

在实际开发中,一般只会前进和后退一层页面,因此vue-router提供了如下两个便捷方法:

1.$router.back()

//在历史记录中,后退到上一个页面

  <button @click="$router.back()">后退</button>

2.$router.forward()

//在历史记录中,后退到下一个页面

  <button @click="$router.forward()">前进</button>