Performance
· 16 checks — Lighthouse + waterfall + sustainability rolled into one auditable list.Performance-focused optimization plan with CWV assessment, top offenders, and time estimates
First Contentful Paint First Contentful Paint — how long until the browser renders the first piece of content. Under 1.8s is good.
6.88 s
Largest Contentful Paint Largest Contentful Paint — how long until the largest visible element loads. Under 2.5s is good.
18.86 s
Total Blocking Time Total Blocking Time — total time the main thread was blocked, preventing user input. Under 200ms is good.
960 ms
Cumulative Layout Shift Cumulative Layout Shift — measures visual stability. How much the page layout shifts during loading. Under 0.1 is good.
0.000
Speed Index Speed Index — how quickly content is visually displayed during load. Under 3.4s is good.
10.82 s
Time to Interactive Time to Interactive — how long until the page is fully interactive and responds to user input. Under 3.8s is good.
19.44 s
Page Load Progression
FPage Weight BudgetAction24.7 MB transferred, 145 requestsFIX
Convert images to WebP/AVIF and resize to display dimensions to reduce transfer size.
Image bandwidth is high — modern formats (WebP/AVIF) and resizing typically cut it 50%+.
Source: web.dev
Subset fonts to include only used characters, or switch to system font stacks.
Font payload is large — subset to used glyphs only, or fall back to system fonts (zero load time).
Source: web.dev font loading
Large JavaScript bundles delay interactivity. Split code by route or defer non-critical scripts.
JavaScript bundle is large — code-split routes and lazy-load off-screen components to defer.
Source: web.dev
Each request adds latency. Bundle small files, use sprites, or eliminate unnecessary requests.
High HTTP request count — bundling, sprite-ing, and HTTP/2 server push can reduce per-request overhead.
Source: web.dev
DThird-Party ImpactAction100% third-party, 0 ms blockingFIX
FJS Execution CostAction6988ms total JS executionFIX
Main Thread Breakdown
| Script | Total | Scripting | Parse/Compile | Party |
|---|---|---|---|---|
| https://hashnode.com/_next/static/chunks/ae0516f9cf0e7561.js | 2202ms | 2011ms | 43ms | 3rd |
| Unattributable | 2123ms | 52ms | 0ms | 3rd |
| https://ping.hashnode.com/gtag/js?id=G-72XG3F8LNJ | 988ms | 700ms | 67ms | 3rd |
| https://hashnode.com/_next/static/chunks/faf4a0202735b81c.js | 609ms | 517ms | 1ms | 3rd |
| https://hashnode.com/ | 441ms | 79ms | 41ms | 3rd |
| https://hashnode.com/_next/static/chunks/d43fa2c261a15769.js | 386ms | 50ms | 21ms | 3rd |
| https://hashnode.com/_next/static/chunks/5d420d97975eccac.js | 113ms | 78ms | 18ms | 3rd |
| https://hashnode.com/_next/static/chunks/2046bca9a9daa3cb.js | 72ms | 7ms | 17ms | 3rd |
| https://hashnode.com/_next/static/chunks/6826dffb999e18eb.js | 54ms | 1ms | 53ms | 3rd |
FHTTP CachingActionNo cache headersFIX
No Cache-Control header
Adding a Cache-Control header can significantly improve repeat-visit performance.
BImage Optimization79 images, 0 KB saveableREVIEW
CJS BundlesAction28 scripts, 199 KB unusedREVIEW
Downloaded but never executed on this page.
| Script | Size | Unused | Minified | Party |
|---|---|---|---|---|
| https://ping.hashnode.com/gtag/js?id=G-72XG3F8LNJ | 205 KB | 58 KB (28%) | ✓ | 3rd |
| https://hashnode.com/_next/static/chunks/ae0516f9cf0e7561.js | 125 KB | 50 KB (41%) | ✓ | 3rd |
| https://hashnode.com/_next/static/chunks/6826dffb999e18eb.js | 75 KB | 43 KB (61%) | ✓ | 3rd |
| https://us-assets.i.posthog.com/static/surveys.js?v=1.357.1 | 32 KB | 25 KB (80%) | ✓ | 3rd |
| https://hashnode.com/_next/static/chunks/d43fa2c261a15769.js | 38 KB | 22 KB (60%) | ✓ | 3rd |
| https://hashnode.com/_next/static/chunks/89bcb98f518389a3.js | 12 KB | — | ✓ | 3rd |
| https://hashnode.com/_next/static/chunks/8c045503bec64188.js | 12 KB | — | ✓ | 3rd |
| https://hashnode.com/_next/static/chunks/73e3194f06db260e.js | 8 KB | — | ✓ | 3rd |
| https://hashnode.com/_next/static/chunks/2939a275487cf6ef.js | 10 KB | — | ✓ | 3rd |
| https://hashnode.com/_next/static/chunks/2963de8af5bf4d07.js | 9 KB | — | ✓ | 3rd |
Consider code splitting or tree shaking to reduce unused code.
This bundle has high unused code — code-split or tree-shake to ship only what executes.
Source: web.dev / Lighthouse coverage
Consider code splitting or tree shaking to reduce unused code.
This bundle has high unused code — code-split or tree-shake to ship only what executes.
Source: web.dev / Lighthouse coverage
Consider code splitting or tree shaking to reduce unused code.
This bundle has high unused code — code-split or tree-shake to ship only what executes.
Source: web.dev / Lighthouse coverage
Consider code splitting or tree shaking to reduce unused code.
This bundle has high unused code — code-split or tree-shake to ship only what executes.
Source: web.dev / Lighthouse coverage
Consider code splitting or tree shaking to reduce unused code.
This bundle has high unused code — code-split or tree-shake to ship only what executes.
Source: web.dev / Lighthouse coverage
A+Text CompressionAll text resources are compressedPASS
A+Font Loading13 fonts (855 KB)PASS
Web fonts
13
855 KB total
Render-blocking
0
of 13
Dominant font-display
swap
Most common across fonts
Font loading timeline
- Subset this font — over 100 KB suggests Latin Extended or full glyph coverage that most pages don't need
Optimization checklist
- Preload critical fonts (priority=high)
- Use woff2 format for all fonts
- Set font-display to swap, optional, or fallback
- Subset large fonts (≤100 KB each)
Fixing the unchecked items could save ~163 KB and ~326 ms
A+Resource CachingAll resources properly cachedPASS
A+Critical Rendering PathNo render-blocking resourcesPASS
A+Resource Hints54 hints, 0 missing preconnectsPASS
Current Resource Hints
54 resource hints configured
A+Render-Blocking ResourcesNo render-blocking resources detectedPASS
A+Third-Party ResourcesNo third-party resources detectedPASS
A+Green HostingWhether the site is served from green-energy infrastructurePASS
Green Hosting
This site is hosted on green energy infrastructure
Provider: Cloudflare
Network Waterfall145 requests over 0msINFO
Performance analysis not available for this result.
Third-Party Script CostPer-script blocking time, transfer cost, and cache headersINFO
| Script | Category | Execution | Transfer | Unused | Monthly Cost | Verdict |
|---|---|---|---|---|---|---|
hashnode.com hashnode.com | Other | 2202ms | 125 KB | 41% | €35/mo | Costly |
Unattributable Unattributable | Other | 2123ms | 0 KB | — | €34/mo | Costly |
ping.hashnode.com ping.hashnode.com | Other | 988ms | 205 KB | 28% | €16/mo | Costly |
hashnode.com hashnode.com | Other | 609ms | 1 KB | — | €10/mo | Costly |
hashnode.com hashnode.com | Other | 441ms | 71 KB | — | €7/mo | Costly |
hashnode.com hashnode.com | Other | 386ms | 38 KB | 60% | €6/mo | Costly |
hashnode.com hashnode.com | Other | 113ms | 30 KB | — | €2/mo | Optional |
hashnode.com hashnode.com | Other | 72ms | 29 KB | — | €1/mo | Optional |
hashnode.com hashnode.com | Other | 54ms | 75 KB | 61% | €1/mo | Optional |
These scripts may cost more than they're worth
- hashnode.com adds 2202ms and costs ~€35/month
- Unattributable adds 2123ms and costs ~€34/month
- ping.hashnode.com adds 988ms and costs ~€16/month
- hashnode.com adds 609ms and costs ~€10/month
- hashnode.com adds 441ms and costs ~€7/month
- hashnode.com adds 386ms and costs ~€6/month
100% of JavaScript execution time is spent on third-party scripts. Consider auditing which scripts are essential.
When third-party JS execution time exceeds your own, performance gains from frontend work are capped by code you don't own.
Learn more ▾ ▴
Every millisecond of third-party JS competes with your own for main-thread time. If their share is bigger than yours, optimization on your code base barely moves the needle. Audit, defer, or remove third-parties before further frontend optimization. Use Lighthouse's third-party audit to identify the worst offenders.
Source: web.dev
hashnode.com takes 2202ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.
This script has high main-thread execution time — optimize hot paths or defer.
Source: web.dev
Unattributable takes 2123ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.
This script has high main-thread execution time — optimize hot paths or defer.
Source: web.dev
ping.hashnode.com takes 988ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.
This script has high main-thread execution time — optimize hot paths or defer.
Source: web.dev
hashnode.com takes 609ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.
This script has high main-thread execution time — optimize hot paths or defer.
Source: web.dev
hashnode.com takes 441ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.
This script has high main-thread execution time — optimize hot paths or defer.
Source: web.dev
hashnode.com takes 386ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.
This script has high main-thread execution time — optimize hot paths or defer.
Source: web.dev
60% of hashnode.com's code is unused. The script may be loading features you don't use.
Bundle has high unused-code ratio — tree-shaking and route-splitting recover the wasted bytes.
Source: web.dev
61% of hashnode.com's code is unused. The script may be loading features you don't use.
Bundle has high unused-code ratio — tree-shaking and route-splitting recover the wasted bytes.
Source: web.dev