Remark Image
Make images compatible with Next.js Image Optimization
Usage
Add it to your Remark plugins.
import { remarkImage } from 'fumadocs-core/mdx-plugins';
export default {
remarkPlugins: [remarkImage],
};
Supported:
- Local Images
- External URLs
- Next.js static imports
How It Works
It transforms your data:image/s3,"s3://crabby-images/f6fd8/f6fd89b43be87e87d25352ca0bc598b569d27551" alt="image"
into Next.js Image usage, and add required props like width
and height
.
By default, it uses static imports to import local images, which supports the placeholder
option of Next.js Image.
Next.js can handle image imports with its built-in image loader.
Otherwise, it uses the file system or an HTTP request to download the image and obtain its size.
Options
Prop | Type | Default |
---|---|---|
publicDir | string | - |
placeholder | "blur" | "none" | 'blur' |
useImport | boolean | true |
external | boolean | true |
Example: With Imports
data:image/s3,"s3://crabby-images/f357a/f357ae31ae0d33ee2846c5bd56189f18e6c8660e" alt="Hello"
data:image/s3,"s3://crabby-images/01a7d/01a7df95a5de36522e05107d2baaaafcfec0f578" alt="Test"
Yields:
import HelloImage from './public/hello.png';
<img alt="Hello" src={HelloImage} />
<img
alt="Test"
src="https://example.com/image.png"
width="1980"
height="1080"
/>
Where ./public/hello.png
points to the image in public directory.
Example: Without Imports
You can disable Next.js static imports on local images.
import { remarkImage } from 'fumadocs-core/mdx-plugins';
export default {
remarkPlugins: [[remarkImage, { useImport: false }]],
};
data:image/s3,"s3://crabby-images/f357a/f357ae31ae0d33ee2846c5bd56189f18e6c8660e" alt="Hello"
data:image/s3,"s3://crabby-images/01a7d/01a7df95a5de36522e05107d2baaaafcfec0f578" alt="Test"
Yields:
<img alt="Hello" src="/hello.png" width="1980" height="1080" />
<img
alt="Test"
src="https://example.com/image.png"
width="1980"
height="1080"
/>
Example: Relative Paths
When useImport
is enabled, you can reference local images using relative paths.
data:image/s3,"s3://crabby-images/56164/5616437e5d5e97758b3b6e587d64184c0b5b934a" alt="Hello"
Be careful that using it with useImport
disabled doesn't work.
Next.js will not add the image to public assets unless you have imported it in code.
For images in public directory, you can just reference them without relative paths.
Example: Public Directory
Customise the path of public directory
import { remarkImage } from 'fumadocs-core/mdx-plugins';
import path from 'node:path';
export default {
remarkPlugins: [
remarkImage,
{
publicDir: path.join(process.cwd(), 'dir'),
},
],
};
You can pass a URL too.
import { remarkImage } from 'fumadocs-core/mdx-plugins';
export default {
remarkPlugins: [
remarkImage,
{
publicDir: 'http://localhost:3000/images',
},
],
};
Last updated on 1/18/2025