A Vue teljesítmény optimalizálása magában foglalja a köteg méretét, a renderelés hatékonyságát és a reaktivitás költségét. Íme a legmagasabb hatású technikák.
1. Kódfelosztás / lusta betöltés
routes = [{ : , : () }];
= ( ());
A Vue teljesítmény optimalizálása magában foglalja a köteg méretét, a renderelés hatékonyságát és a reaktivitás költségét. Íme a legmagasabb hatású technikák.
routes = [{ : , : () }];
= ( ());
A legnagyobb kezdeti terhelési nyereség: ne szállíts olyan kódot, amelyre a felhasználónak még nincs szüksége.
<div v-show="tab === 'a'"> <!-- toggled often → cheap CSS flip -->
<div v-if="rarelyShown"> <!-- rarely rendered → skip building it -->
<li v-for="item in items" :key="item.id"> <!-- enables efficient DOM reuse/diffing -->
import { shallowRef, shallowReactive } from "vue";
// for large objects you replace wholesale (or 3rd-party instances), skip deep tracking
const bigData = shallowRef(hugeObject); // only .value reassignment is reactive
Object.freeze(staticConfig); // never-changing data → no reactivity overhead
A mély reaktivitás nagy objektumokon költséges; a shallowRef/shallowReactive/Object.freeze elkerüli az olyan adatok nyomon követését, amelyekre nincs szükség.
<p>{{ expensiveComputed }}</p> <!-- cached, recomputes only on dependency change -->
<header v-once>{{ siteName }}</header> <!-- render once, never update -->
<div v-memo="[item.id]">...</div> <!-- re-render only if item.id changes -->
Rendering 10,000 rows kills performance → use vue-virtual-scroller / TanStack Virtual
to render only the visible rows.
Vue DevTools (component render timings, why a component re-rendered)
build output / rollup-plugin-visualizer → bundle composition
Lighthouse → Core Web Vitals
A Vue alapértelmezettként gyors, de a nagy alkalmazásoknak szándékos optimalizálásra van szükségük: lusta betöltés a kötegek zsugorításához, válaszd helyesen a v-if/v-show-t, használj stabil kulcsokat, kerüld a túlzott reaktivitást nagy adatokon (shallowRef/freeze), gyorsítótárazz computed/v-memo-val, és virtualizáld a hosszú listákat.
Annak tudása, hogy melyik technika melyik szűk keresztmetszetet kezeli — és a DevTools/Lighthouse segítségével mérés az empirikus megközelítés helyett — az, ami egy növekvő Vue alkalmazást responsívvá tartja.