We use the router-link component to create links to routes with specified query parameters. The “to” prop accepts an object with the path and query properties, allowing you to include query parameters.
Syntax:
<RouterLink :to="{ path: '/yourPath', query: { //yourParams } }" ></RouterLink>
Example: The below JavaScript codes will help you implement the router-link method to set URL query params in Vue with Vue-Router.
Javascript
<!-- src/App.vue file -->
<script>
import {
RouterView,
RouterLink,
useRouter,
useRoute
}
from 'vue-router' ;
const router = useRouter();
const route = useRoute();
export default {
name: '#app' ,
};
</script>
<template>
<nav>
<RouterLink :to= "
{
path: '/',
query: { id: 1 }
}" >Home</RouterLink> |
<RouterLink :to= "
{
path: '/contact',
query: { id: 2 }
}" >Contact</RouterLink> |
<RouterLink :to= "
{
path: '/about',
query: { id: 3 }
}" >About</RouterLink>
</nav>
<RouterView />
</template>
<style>
nav {
width: 100%;
font-size: 24px;
}
nav a {
display: inline-block;
padding: 5px 10px;
margin: 10px;
}
nav a.router-link-exact-active {
background-color: green;
color: #fff;
text-decoration: none;
}
</style>
|
Javascript
import {
createRouter,
createWebHistory
}
from 'vue-router' ;
import HomeView
from './views/HomeView.vue' ;
import ContactView
from './views/ContactView.vue' ;
import AboutView
from './views/AboutView.vue' ;
const router = () =>
createRouter({
history: createWebHistory(),
routes: [
{
path: '/' ,
name: 'home' ,
component: HomeView,
},
{
path: '/about' ,
name: 'about' ,
component: AboutView,
},
{
path: '/contact' ,
name: 'contact' ,
component: ContactView,
},
],
});
export default router;
|
Javascript
const { createApp } = require( 'vue' );
import App from './App.vue' ;
import createRouter from './router' ;
createApp(App).use(createRouter()).mount( '#app' );
|
Javascript
<!-- views/HomeView.vue file -->
<template>
<h1>This is Home Page</h1>
</template>
<script>
export default {}
</script>
|
Javascript
<!-- views/ContactView.vue file -->
<template>
<h1>This is Contact Page</h1>
</template>
<script>
export default {}
</script>
|
Javascript
<!-- views/AboutView.vue file -->
<template>
<h1>This is About Page</h1>
</template>
<script>
export default {};
</script>
|
How to Set URL Query Params in Vue with Vue-Router ?
Vue Router is a navigation library designed specifically for Vue.js applications. In this article, we will learn about the different methods of setting the URL query params in Vue with Vue-Router. Below is the list of all possible methods.
Table of Content
- Using router-link
- Using push() method
- Using replace() method