103 Early Hints
Allow a client to request static assets while waiting for the HTML response.
If you want to get started quickly, click on the button below.
This creates a repository in your GitHub account and deploys the application to Cloudflare Workers.
103 Early Hints is an HTTP status code designed to speed up content delivery. When enabled, Cloudflare can cache the Link headers marked with preload and/or preconnect from HTML pages and serve them in a 103 Early Hints response before reaching the origin server. Browsers can use these hints to fetch linked assets while waiting for the origin’s final response, dramatically improving page load speeds.
To ensure Early Hints are enabled on your zone:
- Log in to the Cloudflare Dashboard ↗ and select your account and website.
- Go to Speed > Optimization > Content Optimization.
- Enable the Early Hints toggle to on.
You can return Link headers from a Worker running on your zone to speed up your page load times.
const CSS = "body { color: red; }";const HTML = `<!doctype html><html lang="en"><head>    <meta charset="utf-8">    <title>Early Hints test</title>    <link rel="stylesheet" href="/test.css"></head><body>    <h1>Early Hints test page</h1></body></html>`;
export default {  async fetch(req) {    // If request is for test.css, serve the raw CSS    if (/test\.css$/.test(req.url)) {      return new Response(CSS, {        headers: {          "content-type": "text/css",        },      });    } else {      // Serve raw HTML using Early Hints for the CSS file      return new Response(HTML, {        headers: {          "content-type": "text/html",          link: "</test.css>; rel=preload; as=style",        },      });    }  },};const CSS = "body { color: red; }";const HTML = `<!doctype html><html lang="en"><head>    <meta charset="utf-8">    <title>Early Hints test</title>    <link rel="stylesheet" href="/test.css"></head><body>    <h1>Early Hints test page</h1></body></html>`;
export default {  async fetch(req): Promise<Response> {    // If request is for test.css, serve the raw CSS    if (/test\.css$/.test(req.url)) {      return new Response(CSS, {        headers: {          "content-type": "text/css",        },      });    } else {      // Serve raw HTML using Early Hints for the CSS file      return new Response(HTML, {        headers: {          "content-type": "text/html",          link: "</test.css>; rel=preload; as=style",        },      });    }  },} satisfies ExportedHandler;import refrom workers import Response
CSS = "body { color: red; }"HTML = """<!doctype html><html lang="en"><head>    <meta charset="utf-8">    <title>Early Hints test</title>    <link rel="stylesheet" href="/test.css"></head><body>    <h1>Early Hints test page</h1></body></html>"""def on_fetch(request):    if re.search("test.css", request.url):        headers = {"content-type": "text/css"}        return Response(CSS, headers=headers)    else:        headers = {"content-type": "text/html","link": "</test.css>; rel=preload; as=style"}        return Response(HTML, headers=headers)import { Hono } from "hono";
const app = new Hono();
const CSS = "body { color: red; }";const HTML = `<!doctype html><html lang="en"><head>    <meta charset="utf-8">    <title>Early Hints test</title>    <link rel="stylesheet" href="/test.css"></head><body>    <h1>Early Hints test page</h1></body></html>`;
// Serve CSS fileapp.get("/test.css", (c) => {  return c.body(CSS, {    headers: {      "content-type": "text/css",    },  });});
// Serve HTML with early hintsapp.get("*", (c) => {  return c.html(HTML, {    headers: {      link: "</test.css>; rel=preload; as=style",    },  });});
export default app;Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark