ImageResponse
API Reference for the ImageResponse constructor.
The ImageResponse constructor allows you to generate dynamic images using JSX and CSS. This is useful for generating social media images such as Open Graph images, Twitter cards, and more.
Reference
Parameters
The following parameters are available for ImageResponse:
Examples are available in the Vercel OG Playground.
Supported HTML and CSS features
ImageResponse supports common CSS properties including flexbox and absolute positioning, custom fonts, text wrapping, centering, and nested images.
Please refer to Satori’s documentation for a list of supported HTML and CSS features.
Behavior
ImageResponseuses @vercel/og, Satori, and Resvg to convert HTML and CSS into PNG.- Only flexbox and a subset of CSS properties are supported. Advanced layouts (e.g.
display: grid) will not work. - Maximum bundle size of
500KB. The bundle size includes your JSX, CSS, fonts, images, and any other assets. If you exceed the limit, consider reducing the size of any assets or fetching at runtime. - Only
ttf,otf, andwofffont formats are supported. To maximize the font parsing speed,ttforotfare preferred overwoff.
Examples
Route Handlers
ImageResponse can be used in Route Handlers to generate images dynamically at request time.
File-based Metadata
You can use ImageResponse in a opengraph-image.tsx file to generate Open Graph images at build time or dynamically at request time.
Custom fonts
You can use custom fonts in your ImageResponse by providing a fonts array in the options.
Version History
| Version | Changes |
|---|---|
v14.0.0 | ImageResponse moved from next/server to next/og |
v13.3.0 | ImageResponse can be imported from next/server. |
v13.0.0 | ImageResponse introduced via @vercel/og package. |