I am using Nuxt and Vue and I am trying to submit a form, redirect the user to a new route including the submitted params, send an API request to get some data and then render that data.
I achieved this by simply setting the form action to the new path and manually adding all the URL parameters to the API request.
First I create a simple form with the route /search
.
<form action="/search">
<input type="text" name="foobar">
<button type="submit">Submit</button>
</form>
When submitting the form the user leaves the current page and gets redirected to the new page. The URL would now look like this: http://www.example.com/search?foobar=test
. Now I fetch the foobar
parameter by using this.$route.query.foobar
and send it to my API.
However the problem in my approach is when submitting the form the user leaves the current page and a new page load will occur. This is not what we want when building progressive web apps.
So my question is how can I submit a form in Nuxt/Vue and redirect to a new route including the submitted parameters?
The default behavior of
<form>
is to reload the pageonsubmit
. When implementing SPA's it would be better to avoid invoking default behavior of<form>
.Making use of
router module
which is available out-of-box in nuxtjs will enable all the redirection controls to flow within the application. if we try to trigger events available via<form>
then browser reload will occur. This has to be avoided.You can try below approach
First
Use
.stop.prevent
modifiers to prevent the submit button from invoking default<form>
behavior. This is similar to usingevent.stopPropagation();
andevent.preventDefault();
in jQueryThen
Create
vue model object
foobar
vue method
submit
Use
this.$router.push
to redirect to next page. This will enable the control flow to stay inside the SPA. if you want to send any data into server then you can do it before invokingthis.$router.push
else you can redirect and continue your logic.just add this: @submit.prevent="false"
i hope this be useful for u :)