-
Notifications
You must be signed in to change notification settings - Fork 155
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
perf: speed up network load times #10976
Conversation
Removes the manual chunking which put all vendor libraries into one chunk. As a result, this chunk was huge and took quite some time to be loaded, especially with slower network connections. While there might be a case for using (meaningful) manual chunks, it needs more testing. Also, I noticed that it can mess with dynamic imports.
Thanks for opening this pull request! The maintainers of this repository would appreciate it if you would create a changelog item based on your changes. |
6ef68c7
to
6bad216
Compare
This way we can avoid loading the huge toast-ui editor dependency on page load.
Fixes all circular import issues since they could mess with rollup's ability to properly chunk js files.
6bad216
to
2260589
Compare
Quality Gate passedIssues Measures |
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.
🚀 🚀 🚀
Description
This PR improves network load times by taking the following actions:
Remove manual vendor chunking
The manual chunking we had put all vendor libraries into one chunk. As a result, this chunk was huge and took quite some time to be loaded, especially with slower network connections.
While there might be a case for using (meaningful) manual chunks, it needs more testing. Also, I noticed that it can mess with dynamic imports.
Lazy load dependencies
Large dependencies are now being lazy loaded, meaning they are not automatically loaded on page load. The most critical library is the toast editor, which is is simply an insanely huge library.
The following libs are affected:
v-calendar
dependency inOcDatepicker
emoji-mart
dependency inOcEmojiPicker
epubjs
dependencies)TextEditor
component (holds the toast-ui dependencies)Lazy load translations of core packages
Especially the translations in
web-pkg
are quite large, hence we now load them dynamically during the bootstrap process of Web.Fix circular import issues
All circular import issues have been fixed, since they may affect rollup's ability to create proper chunks.
Benchmarks
Network load time
master
: load 300-400ms, finish 1.2sv8.0.2
: load 150-200ms, finish 1.5sPR
: load 200ms, finish 800msNetwork load time (Chrome profile "Fast 3G")
master
: load 27s, finish 40sv8.0.2
: load 20s, finish 33sPR
: load 15s, finish 30sLighthouse (speed index)
master
: 4.7sv8.0.2
: 3.7sPR
: 3.2sFurther steps
As the benchmarks show, while things have improved, they are still far from great. The following steps could (should?) be evaluated next:
Enable server text compression
Static JS and CSS files could easily be compressed by the server, reducing the size of the chunks by a lot (see https://developer.chrome.com/docs/lighthouse/performance/uses-text-compression?utm_source=lighthouse&utm_medium=devtools). I tested this locally by adding a middleware in oCIS (the Chi router already ships one) and things looked good. Is there a reason we don't have this?
Split CSS into multiple chunks
Currently we're setting
cssCodeSplit: false
, which results in one big CSS file. We should enable this, however, there is an issue where some CSS definitions will be put into chunks that are never loaded. Needs investigation.Lazy load more components
Especially components that are registered by extensions (e.g. sidebar panels, search components) can easily be lazy loaded. I guess it would make sense, since extensions are being registered and loaded with the initial page load, although their components might not need to be.
Lazy load routes
This one I'm really not sure about. I tried lazy loading all our routes, especially since the vue-router docs recommend doing it. While it does have a positive effect on the initial page load time, it also has a negative effect: When you navigate to another (not loaded) route after the initial load, there is a slight delay because the browser fetches the new stuff. In production build I don't really notice it, but with
pnpm vite
and with a slower network connection I definitely do.We could overcome this issue by using a wrapper component that shows a loading spinner while the async component is loading.
Another thing to note is that lazy routes would help with the CSS split, since CSS from lazy routes will definitely be loaded when the component of such a route is being rendered.
I'm torn on this one 🤷
Related Issue
Types of changes