Circular reference problem in Vue

Published at 2020/05/21

For the last couple days I've been working on a component that is meant to reuse itself if needed recursively. Everything was going smooth until I've met the case where it actually had an opportunity to do it. Unfortunately, I've got an error:

[Vue warn]: Unknown custom element: XYZ - did you register the component correctly? For recursive components, make sure to provide the "name" option.

I was confused. Why does it throw me such error if everything seems to be just fine, I've already registered the component's name, everything was on its place.

When I double-checked all the stuff I thought might relate to this error message, I've started blind guessing - change this or change that and see what happens. But nothing was preventing error from being thrown.

Until I've commented out the component's calling itself it its template part.

I was then: OK, so this is really something related to component's recursion - but what's going on exacltly? I'm providing name option and all the other stuff.

Then, I've found out this nice piece of Vue documentation, Handling edge cases:

To explain what’s happening, let’s call our components A and B. The module system sees that it needs A, but first A needs B, but B needs A, but A needs B, etc. It’s stuck in a loop, not knowing how to fully resolve either component without first resolving the other.

And to solve that, you can wait until beforeCreate lifecycle with registering the component:

beforeCreate () {
  this.$options.components.XyzComponent = require('@/components/Xyz/XyzComponent.vue').default
}

but personally, I prefer another option, that is using Webpack's asynchronous import:

components: {
  XyzComponent: () => import('@/components/Xyz/XyzComponent.vue')
}

And voila! It should fix the case related to circular component references.

-- ł.

Click here to show comments