VUE路由跳转

vue路由跳转四种类型

1:router-link跳转

1.不带参数

<router-link :to="{name:'home'}">

<router-link :to="{path:'/home'}"> //name,path都行, 建议用name

// 注意:router-link中链接如果是'/'开始就是从根路由开始;如果不带'/',则从当前路由开始。


2.带params参数

<router-link :to="{name:'home', params: {id:123456}}">

// params传参数 (类似post)

// 路由配置 path: "/home/:id" 或者 path: "/home:id"

// 不配置path ,第一次可请求,刷新页面id会消失;配置path,刷新页面id会保留。

// html 取参 $route.params.id script 取参 this.$route.params.id


3.带query参数

<router-link :to="{name:'home', query: {id:123456}}">

// query传参数 (类似get,url后面会显示参数)

// 路由可不配置

// html 取参 $route.query.id script 取参 this.$route.query.id

2:this.$router.push()

1. 不带参数

this.$router.push('/home')

this.$router.push({name:'home'})

this.$router.push({path:'/home'})


2. query传参

this.$router.push({name:'home',query: {id:'123456'}})

this.$router.push({path:'/home',query: {id:'123456'}})

// html 取参 $route.query.id script 取参 this.$route.query.id


3. params传参

this.$router.push({name:'home',params: {id:'123456'}}) // 只能用 name

// 路由配置 path: "/home/:id" 或者 path: "/home:id" ,

// 不配置path ,第一次可请求,刷新页面id会消失

// 配置path,刷新页面id会保留

// html 取参 $route.params.id script 取参 this.$route.params.id


4. query和params区别

query类似get, 跳转之后页面url后面会拼接参数,类似?id=123456, 非重要性的可以这样传, 密码之类还是用params刷新页面id还在

params类似post, 跳转之后页面url后面不会拼接参数, 但是刷新页面id会消失。
3.  this.$router.replace() 

用法同上,和第2个的this.$router.push方法一样。

4.  this.$router.go(n) 

<button @click="upPage">[上一页]</button>

<button @click="downPage">[下一页]</button>

upPage() {

this.$router.go(-1); // 后退一步记录,等同于 history.back()

},

downPage() {

this.$router.go(1); // 在浏览器记录中前进一步,等同于 history.forward()

}

向前或者向后跳转n个页面,n可为正整数或负整数

ps : 区别

this.$router.push

跳转到指定url路径,并向history栈中添加一个记录,点击后退会返回到上一个页面。

this.$router.replace

跳转到指定url路径,但是history栈中不会有记录,点击返回会跳转到上个页面 (直接替换当前页面)。

this.$router.go(n)

向前或者向后跳转n个页面,n可为正整数或负整数。

实例

vue-router 中并不一定要通过router-link才能实现路径的跳转

可以自定义元素节点,给元素节点添加点击事件和方法,在方法里面通过适当的方式,来改变vue当前的路由,从而实现vue路由的单页面响应

<button @click="home">home</button>
<button @click="about">about</button>

通过处理点击事件,利用this.$router.replace()方法,来改变当前的路由

var vm = new Vue({
	el:'root',
	methods:{
		home:function(){
			this.$router.replace('/home')
			//this.$router.push('/home')
		},
		about:function(){
			this.$router.replace('/about')
			//this.$router.push('/about')
		}
	}
})
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值