vue路由带参跳转遇到的问题

1 篇文章 0 订阅

关于this.$route.push({path:‘xxx/xxx’,query:’’})遇到的问题

一般情况下大家都是从列表页跳转到详情页 ,会前端带参数对象过去,但是如果使用
this.$route.push({name:'xxxx/xxx',params:{}})的话 ,需要在router里配置name,不能和path直接使用,所以一般都会使用this.$route.push({path:'${路由}',query:{}})来处理,但是这里有一个问题:
刚进入详情的时候是好的,到那时刷新浏览器之后就会报错[Object Object]的错,通过query传过来的对象会失效,所以在解决这个问题的时候,我一般采用 JSON.strinngfy()去字符串化,在放入query传过去,到对应页面后在转回对象,就不会有刷新,取不到数据的问题了。

随手一记,如果还有更好的简单快捷的方法,请兄弟姐妹们慷慨告知,哈哈,感激不尽!!!!!

Vue 2 中,你可以使用 Vue Router 来进行带参数的路由跳转。以下是一个示例代码: 首先,你需要在路由配置中定义带参数的路由路径。你可以使用 `:` 来指定参数的占位符。 ```javascript // 路由配置 import Vue from 'vue'; import VueRouter from 'vue-router'; Vue.use(VueRouter); const routes = [ { path: '/user/:id', name: 'User', component: UserComponent, }, ]; const router = new VueRouter({ routes, }); ``` 在上述示例中,我们定义了一个带参数的路由 `/user/:id`,其中 `:id` 是参数的占位符。 接下来,你可以使用 `router-link` 组件或编程式导航来实现带参数的路由跳转。 使用 `router-link` 组件: ```html <router-link :to="'/user/' + userId">Go to User</router-link> ``` 在上述示例中,我们使用了动态绑定 `:to` 属性,并通过拼接字符串的方式传递参数。 使用编程式导航: ```javascript // 在组件中 this.$router.push('/user/' + userId); ``` 在上述示例中,我们使用 `$router.push()` 方法来进行编程式导航,同样是通过拼接字符串的方式传递参数。 无论是使用 `router-link` 还是编程式导航,都可以带参数进行路由跳转。在目标页面中,你可以通过 `$route.params` 来获取传递的参数。 ```javascript // 在目标组件中获取参数 mounted() { const userId = this.$route.params.id; console.log(userId); } ``` 在上述示例中,我们通过 `$route.params` 获取了传递的参数,并输出到控制台。 希望这可以帮助到你!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值