How to set URL query params in Vue with Vue-Router

前端 未结 9 744
梦如初夏
梦如初夏 2020-12-23 20:24

I am trying to set query params with Vue-router when changing input fields, I don\'t want to navigate to some other page but just want to modify url query params on the same

相关标签:
9条回答
  • 2020-12-23 20:28

    Here is the example in docs:

    // with query, resulting in /register?plan=private
    router.push({ path: 'register', query: { plan: 'private' }})
    

    Ref: https://router.vuejs.org/en/essentials/navigation.html

    As mentioned in those docs, router.replace works like router.push

    So, you seem to have it right in your sample code in question. But I think you may need to include either name or path parameter also, so that the router has some route to navigate to. Without a name or path, it does not look very meaningful.

    This is my current understanding now:

    • query is optional for router - some additional info for the component to construct the view
    • name or path is mandatory - it decides what component to show in your <router-view>.

    That might be the missing thing in your sample code.

    EDIT: Additional details after comments

    Have you tried using named routes in this case? You have dynamic routes, and it is easier to provide params and query separately:

    routes: [
        { name: 'user-view', path: '/user/:id', component: UserView },
        // other routes
    ]
    

    and then in your methods:

    this.$router.replace({ name: "user-view", params: {id:"123"}, query: {q1: "q1"} })
    

    Technically there is no difference between the above and this.$router.replace({path: "/user/123", query:{q1: "q1"}}), but it is easier to supply dynamic params on named routes than composing the route string. But in either cases, query params should be taken into account. In either case, I couldn't find anything wrong with the way query params are handled.

    After you are inside the route, you can fetch your dynamic params as this.$route.params.id and your query params as this.$route.query.q1.

    0 讨论(0)
  • 2020-12-23 20:29

    If you are trying to keep some parameters, while changing others, be sure to copy the state of the vue router query and not reuse it.

    This works, since you are making an unreferenced copy:

      const query = Object.assign({}, this.$route.query);
      query.page = page;
      query.limit = rowsPerPage;
      await this.$router.push({ query });
    

    while below will lead to Vue Router thinking you are reusing the same query and lead to the NavigationDuplicated error:

      const query = this.$route.query;
      query.page = page;
      query.limit = rowsPerPage;
      await this.$router.push({ query });
    

    Of course, you could decompose the query object, such as follows, but you'll need to be aware of all the query parameters to your page, otherwise you risk losing them in the resultant navigation.

      const { page, limit, ...otherParams } = this.$route.query;
      await this.$router.push(Object.assign({
        page: page,
        limit: rowsPerPage
      }, otherParams));
    );
    

    Note, while the above example is for push(), this works with replace() too.

    Tested with vue-router 3.1.6.

    0 讨论(0)
  • 2020-12-23 20:36

    Here's my simple solution to update the query params in the URL without refreshing the page. Make sure it works for your use case.

    const query = { ...this.$route.query, someParam: 'some-value' };
    this.$router.replace({ query });
    
    0 讨论(0)
  • 2020-12-23 20:37

    For adding multiple query params, this is what worked for me (from here https://forum.vuejs.org/t/vue-router-programmatically-append-to-querystring/3655/5).

    an answer above was close … though with Object.assign it will mutate this.$route.query which is not what you want to do … make sure the first argument is {} when doing Object.assign

    this.$router.push({ query: Object.assign({}, this.$route.query, { newKey: 'newValue' }) });
    
    0 讨论(0)
  • 2020-12-23 20:46

    Actually you can just push query like this: this.$router.push({query: {plan: 'private'}})

    Based on: https://github.com/vuejs/vue-router/issues/1631

    0 讨论(0)
  • 2020-12-23 20:46
    this.$router.push({ query: Object.assign(this.$route.query, { new: 'param' }) })
    
    0 讨论(0)
提交回复
热议问题