-
-
Notifications
You must be signed in to change notification settings - Fork 341
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Vue] Add support for lazy-loading with Async Components #482
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is awesome! I've never used defineAsycComponent
and require.context
is always complex :). But you've got the tests, I love it.
Do you have anything else you need to do?
Thanks for the review @weaverryan! On this PR, I think nothing is missing, however I thought about a usecase for a 2nd PR: I think some people would like to have both lazy-loaded and not lazy-loaded controllers/components at the same time. Currently, that's not possible to have both registerVueControllerComponents(require.context('./vue/controllers', true, /\.vue$/));
registerVueControllerComponents(require.context('./vue/controllers-lazy', true, /\.vue$/, 'lazy')); because |
4305e5a
to
8fa08d0
Compare
Thanks Hugo! |
I was a bit surprised when trying the Symfony UX' Vue integration, to see all Vue components/controllers to be loaded to render at least only one controllers.
This PR aims to reduce the bundle size and only load the required code and Vue controllers to render on the page.
To enable lazy-loading, add the 4th parameter
"lazy"
torequire.context()
:Note: the sync-loading still works
Real life example
Given 6 really simple Vue controllers which all look the same:
data:image/s3,"s3://crabby-images/b24d4/b24d4af60f05e968368f64680861a10f064752f9" alt="image"
If I render only two of them on a single page:
data:image/s3,"s3://crabby-images/c3dab/c3dab7c9d1df66337325af2646d4af741fb36a89" alt="image"
Before
You can see the
app.js
is about 4.8 kB, it contains all of the 6 Vue controllers.After
You can see the
app.js
is now about 3.4 kB, and two more files have been lazy-loaded (our two Vue controllers rendered on the page).On a real project, with a lot of Vue controllers, the difference would be very significative. I will try to post some results when migrating our main project at work.
Note:
I still have to add tests and update the documentation.done