Javascript Performance
Collections
- RAIL 모델을 사용한 성능 측정
- 응답: 50ms 미만으로 이벤트 처리
- 애니메이션: 10ms 안에 프레임 생성
- 로드: 5초 이내에 콘텐츠를 전달하고 상호 작용 준비하기
- RAIL 측정 도구
- New browser APIs to detect JavaScript performance problems in production
- How JavaScript engines achieve great performance
- Add a Service Worker to Your Site: Serve frequently accessed assets from your local cache instead of the network, reducing data usage and improving performance.
- 12 Front End Performance Patterns You Need to Know
- SSG with SWR
- Use Responsive, Compressed, WebP Formatted Images, Served via a CDN
- Minify, Compress, & Serve Your Static Code Files via a CDN
- Prefetching
- Lazy Loading
- Caching
- Speeding up VSCode (extensions) in 2022
- Patterns.dev is a free book on design patterns and component patterns for building powerful web apps with vanilla JavaScript and React.
- Precise Timing With Web Animations API
- Speeding up the JavaScript ecosystem - eslint
- Mastering the Art of Efficient JavaScript DOM Manipulation
- Use document fragments
- Use event delegation -
event.target.matches
- In Defence of DOMContentLoaded
The DOMContentLoaded event fires once all of your deferred JavaScript has finished running.
- Speeding up the JavaScript ecosystem - Polyfills gone rogue
Many popular npm packages depend on 6-8x more packages than they need to. Most of these are unnecessary polyfills.
- Optimizing Javascript for fun and for profit
- JavaScript Benchmarking Is a Mess
- The garbage collector and its tendency to pause everything randomly
- The JIT compiler’s ability to delete all of your code because it “isn’t necessary”
- Terribly broad flame graphs in most JavaScript devtools
Speeding up the JavaScript ecosystem - The barrel file debacle
The use of barrel files, which only re-export other files, is very common in large JavaScript projects.
However, they can significantly slow down development tasks by forcing the rebuilding of the entire module graph for every file. This is because JavaScript engines must fully parse and evaluate all import statements.
The article provides data showing that constructing the module graph for 10 files is much faster than for 30,000 files. Barrel files can cause test runners to waste minutes rebuilding the graph for each test. Linters are also severely impacted, sometimes taking hours to run.
Removing unnecessary barrel files can dramatically improve performance, speeding up builds by 60-80% according to the author.
JavaScript Hydration Is a Workaround, Not a Solution
JavaScript hydration is a technique used to add interactivity to server-rendered HTML pages by attaching event handlers to DOM elements on the client-side.
However, this process requires recovering the necessary information to rebuild the application state and framework state. The document argues that hydration is an overhead because it duplicates the work already done by the server.
A better approach called resumability avoids this overhead by serializing and transferring the necessary information from server to client. This allows lazy execution of event handlers on the client-side instead of eagerly executing all components.
Children