O que é Code Splitting?
Definição Rápida
O code splitting é uma técnica de optimização que divide o código JavaScript de uma aplicação em partes menores que podem ser carregadas a pedido, reduzindo o tamanho inicial do bundle.
Modern web applications can have millions of lines of JavaScript. Without code splitting, all of this code gets bundled into a single file that every user must download before the application becomes interactive — even if they only visit one page.
Code splitting divides the application bundle into smaller chunks based on routes, components, or features. When a user visits the homepage, they only download the homepage code. When they navigate to the settings page, that code loads on demand. Libraries used only in specific features are split into their own chunks.
There are several approaches to code splitting. Route-based splitting loads code for each page separately (the most common approach). Component-based splitting loads heavy components on demand (like a rich text editor that's only needed when editing). Library splitting separates third-party dependencies into their own cacheable chunks.
Frameworks like Next.js implement route-based code splitting automatically. For component-level splitting, React's lazy() and Suspense enable developers to load components on demand. Webpack, Vite, and other bundlers handle the actual chunk creation and loading logic.
Por Que é Importante
Without code splitting, every user downloads your entire application regardless of what they need. For a large application, this could mean 2-5MB of JavaScript that blocks the page from becoming interactive. Code splitting can reduce the initial download by 60-80%.
This directly impacts Time to Interactive (TTI) and First Input Delay (FID), both critical Core Web Vitals that affect user experience and SEO rankings.
Exemplos Reais
A SaaS dashboard reduced their initial JavaScript bundle from 3.2MB to 450KB through route-based code splitting, making the login page load in under 2 seconds instead of 8
An e-commerce site lazy-loaded their product review component (which included a heavy rich-text editor), saving 200KB from the initial product page load
A Next.js application automatically code-splits by route, so their 50-page application's homepage only loads 120KB of JavaScript instead of the total 4MB
A web app split their charting library into a separate chunk, so users who never visit the analytics dashboard don't download the 500KB chart library
Termos Relacionados
Page Speed
A velocidade de página é a medida de quão rapidamente uma página web carrega e se torna interactiva, impactando directamente a experiência do utilizador e as classificações nos motores de pesquisa.
Lazy Loading
O lazy loading é uma técnica que adia o carregamento de recursos não críticos, como imagens abaixo do fold, até que sejam realmente necessários.
Minification
A minificação é o processo de eliminar caracteres desnecessários do código-fonte — CSS, JavaScript ou HTML — para reduzir o tamanho dos ficheiros.
Core Web Vitals
As Core Web Vitals são três métricas específicas definidas pela Google que medem a experiência real dos utilizadores nos websites: desempenho de carregamento (LCP), interactividade (INP) e estabilidade visual (CLS).
Precisa de ajuda com code splitting?
A nossa equipa pode ajudá-lo a colocar este conceito em prática. Obtenha uma consulta gratuita para falar sobre o seu projecto.