vue中页面间跳转传值的两种方式(query,params)

LinMeng 72 0

两者都可以传递参数,区别是什么?

query 传参配置的是path,而params传参配置的是name,在params中配置path无效 query在路由配置不需要设置参数,而params必须设置 query传递的参数会显示在地址栏中 params传参刷新会无效,但是query会保存传递过来的值,刷新不变 ;

    this.$router.push({
      path: '/home',
      query: {
        site: [],
        bu: []
      }
    })
params:
  this.$router.push({
    name: 'Home',  // 路由的名称
    params: {
      site: [],
      bu: []
    }
  })
params:/router1/:id ,/router1/123,/router1/789 ,这里的id叫做params
query:/router1?id=123 ,/router1?id=456 ,这里的id叫做query。

路由的配置

  {
  path: '/home',
  name: Home,
  component: Home
  }
  params:
  {
  path: '/home/:site/:bu',
  name: Home,
  component: Home
  }

如果路由上面不写参数,也是可以传过去的,但不会在url上面显示出你的参数,并且当你跳到别的页面或者刷新页面的时候参数会丢失,那依赖这个参数的http请求或者其他操作就会失败 在接收跳转的页面获取路由参数:

let self = this
self.getParams()
},
watch () {
'$route': 'getParams'
},
methods: {
  getParams () {
  let site = this.$route.query.site
  let bu = this.$route.query.bu
  // 如果是params 传参,那就是this.$route.params.site
  上面就可以获取到传递的参数了
 }

注意:获取路由上面的参数,用的是$route,后面没有r;

  1. params是路由的一部分,必须要有。query是拼接在url后面的参数,没有也没关系。
  2. params一旦设置在路由,params就是路由的一部分,如果这个路由有params传参,但是在跳转的时候没有传这个参数,会导致跳转失败或者页面会没有内容。
  3. params、query不设置也可以传参,但是params不设置的时候,刷新页面或者返回参数会丢失,query并不会出现这种情况,这一点的在上面说过.

    最后总结:

    路由传递参数和传统传递参数是一样的,命名路由类似表单提交而查询就是url传递:
  4. 命名路由搭配params,刷新页面参数会丢失
  5. 查询参数搭配query,刷新页面数据不会丢失
  6. 接收参数使用this.$router后面就是搭配路由的名称就能获取到参数的值
收藏
评论区