We are building an enormous website based on Vue and Nuxt with over 25 different page types that cannot be matched with standard /:id or /overview/:slug logic that comes out of the box with Vue Router.
As slug-matching isn't an option, we are thinking about the following solution:
- User visits page "/this-is-a-topic-page"
- Server calls API that returns the pageType
topicPage
topicPage
relates to the nuxt pageWpTopicPage
- We set
WpTopicPage
as our component within our wildcard instance of Vue Router
This looks like the following in code:
export function createRouter() {
return new Router({
mode: 'history',
routes: [
// 1. User visits page "/this-is-a-topic-page"
{
name: 'wildcard',
path: '*',
component: *, // this should be dynamic
beforeEnter: (to, from, next) => {
// 2. Server calls API that returns the pageType `topicPage`
this.$axios.get(`/call-to-the-api?slug=${to.params.slug}`)
.then((res) => {
// 3. `topicPage` relates to the nuxt page `WpTopicPage`
if(res.data.pageType === 'topicPage') {
// 4. Set `WpTopicPage` as our Page component
return WpTopicPage;
}
})
},
},
],
});
}
The above obviously doesn't work. Is there a way to set the component
within a route dynamically in the beforeEnter function?
It's possible to do. I have created a codepen for you to test:
Here it is:
This is the output:
As you can see in the console logs - each time something changes we get random component loaded and mounted.