Vue Router的query对象值的问题

      在使用 $router.push() 时,如果使用了query,则可以在跳转后从query中获取到对应的参数

      如果传的是字符串自然没问题,但是如果传的其他类型的数据,在跳转之前是正常的,而跳转之后再刷新一遍页面的话,query里面属性的值都会变成字符串

      因为刷新后query的值是直接从页面URL中取的,而在页面URL上的参数只能是字符串类型

       解决方法:

      在传值之前把要传的参数单独放到一个对象里,再放到query里面,然后进行JSON.stringify()处理

      到了目标页面后再进行JSON.parse()处理,还原为对象

 

      优点:可以一次性处理多个参数,适用度高
 
  例子:
       // this.$router.push({ path: "/video/detail", query: item }); 
  // ({}).toString() => [object Object]
      // this.$router.push({ path: "/video/detail", query: { item } }); 
 this.$router.push({
        path: "/video/detail",
        query: { item: JSON.stringify(item) },
 });
 console.log(JSON.parse(this.$route.query.item));
posted @ 2022-05-14 18:02  WANG灬  阅读(532)  评论(0编辑  收藏  举报