NextJS中文文档 - Image
Next.js Image 组件扩展了 HTML <img>
元素,实现自动图像优化。
jsx
import Image from 'next/image'
export default function Page() {
return <Image src="/profile.png" width={500} height={500} alt="作者的照片" />
}
参考
属性
以下属性可用:
属性 | 示例 | 类型 | 状态 |
---|---|---|---|
src | src="/profile.png" | String | 必填 |
alt | alt="作者的照片" | String | 必填 |
width | width={500} | Integer (px) | - |
height | height={500} | Integer (px) | - |
fill | fill={true} | Boolean | - |
loader | loader={imageLoader} | Function | - |
sizes | sizes="(max-width: 768px) 100vw, 33vw" | String | - |
quality | quality={80} | Integer (100) | - |
priority | priority={true} | Boolean | - |
placeholder | placeholder="blur" | String | - |
style | style='{\{margin: 10px}\}' | Object | - |
onLoadingComplete | onLoadingComplete={img => done()} | Function | 已弃用 |
onLoad | onLoad={event => done()} | Function | - |
onError | onError={event => fail()} | Function | - |
loading | loading="lazy" | String | - |
blurDataURL | blurDataURL=""
width={700}
height={475}
/>
</div>
)
}
你可以使用 Plaiceholder 等工具生成 blurDataURL
值。
overrideSrc
可选属性,设置覆盖主图像 src 的值。
jsx
export function MySmallImage({ src, ...props }) {
// 优先渲染适合 SEO 的小图像版本,但在后台加载高清版本
// 例如 Twitter 卡片,它只能显示每张图像第一帧
return <Image {...props} src={src} overrideSrc={`${src}&preview=1&size=500`} loading="eager" />
}
Advanced
以下配置项可以在 next.config.js
中设置,以便在整个应用程序中配置 Image 组件的行为。
远程模式
为了保护你的应用程序免受恶意用户的攻击,必须为外部图像提供配置。这是为了确保 Next.js 图像优化 API 只能用于优化保存在托管 Next.js 应用程序的相同服务器上的图像,或者优化来自授权来源的图像。
在 next.config.js
文件中添加 remotePatterns
以指定允许哪些外部 URL 用于第 src
参数中的图像元素。
js
module.exports = {
images: {
remotePatterns: [
{
protocol: 'https',
hostname: 'example.com',
port: '',
pathname: '/account123/**',
},
],
},
}
注意:上述示例只有与
https://example.com/account123/...
模式匹配的 URL 才允许被使用。更宽松的设置是仅提供protocol
和hostname
,让pathname
为空,这将允许任何路径。
下面是 remotePatterns
配置的完整内容,可用于限制外部 URL:
protocol
:允许的协议:http
或https
。hostname
:允许的主机名。port
:允许的端口。pathname
:允许的路径模式。必须以/
开头。- 使用
/**
允许任何路径。 - 使用
/foo/**
允许任何以/foo/
开头的路径。 - 使用
/foo/bar
只允许确切的/foo/bar
路径。 - 默认情况下要求路径和参数精确匹配。
- 使用
须知:在 Next.js 13.4.0 及之后,不再支持
domains
,因为它缺乏与remotePatterns
相同的安全约束。我们强烈建议使用remotePatterns
代替,它更安全。
加载器
如果你想要使用云提供商优化图像,而不是使用 Next.js 内置的图像优化 API,你可以在 next.config.js
中配置 loader
和 loaderFile
。
以下 loader
字符串值可使用:
'default'
:使用 Next.js 的内置图像优化 API'imgix'
:使用 Imgix'cloudinary'
:使用 Cloudinary'akamai'
:使用 Akamai 图像优化 API'custom'
:使用自定义 loader 实现
如果你需要指定自定义 loader,你可以使用 loaderFile
配置项,它接收一个文件路径,该文件导出一个返回字符串的 load
函数。
例如:
jsx
module.exports = {
images: {
loader: 'custom',
loaderFile: './my/image/loader.js',
},
}
jsx
export default function myImageLoader({ src, width, quality }) {
return `https://example.com/${src}?w=${width}&q=${quality || 75}`
}
使用 loader 时,总是检查 width
、quality
和其他支持的参数是否正确传递。例如,你可能想要改变 quality
参数来匹配你的自定义 API。
设备尺寸
如果你知道用户的设备宽度,你可以在 next.config.js
中设置 deviceSizes
属性。这些宽度会与 sizes
属性一起使用,以确定最佳的图像尺寸。
如果没有提供 sizes
属性,则会使用 layout='responsive'
或 layout='fill'
以确定所需的图像宽度。
如果 deviceSizes
和 imageSizes
数组的长度大于 25,则 Image 优化的开发构建将会失败。
图像尺寸
你可以在 next.config.js
中设置 imageSizes
属性。当 sizes
属性用于描述小于最小设备宽度的图像宽度时,这些宽度会与 deviceSizes
结合使用。
如果没有提供 sizes
属性,则会使用 layout='fixed'
或 layout='intrinsic'
以确定所需的图像宽度。
使用 width
属性的图像将使用 deviceSizes
和 imageSizes
的结合来查找最接近的匹配。
接受的格式
默认的 接受 头将包括:image/webp
。
您可以通过设置 next.config.js
中的 formats
数组来配置接受的优化格式:
jsx
module.exports = {
images: {
formats: ['image/avif', 'image/webp'],
},
}
目前支持的格式有 image/avif
和 image/webp
。默认值为 ['image/webp']
。
如果提供了 image/avif
,它将首先被尝试,因为它比 image/webp
的压缩效果更好。如果浏览器不支持 AVIF,则 image/webp
是下一个选择。
视口尺寸
您可能需要明确定义给定应用程序的最大视口宽度,这不仅可以用于确保 srcset
格式不会超过这些尺寸,还可以用于确保您的布局不会发生溢出。
以下配置会将最大宽度限制为 1920px,避免超宽视口加载不必要大的图像:
jsx
module.exports = {
images: {
deviceSizes: [640, 768, 1024, 1280, 1536, 1920],
},
}
版本历史
版本 | 变更 |
---|---|
v15.3.0 | remotePatterns 增加了对 URL 对象数组的支持。 |
v15.0.0 | contentDispositionType 配置默认值改为 attachment 。 |
v14.2.23 | 添加了 qualities 配置。 |
v14.2.15 | 添加了 decoding 属性和 localPatterns 配置。 |
v14.2.14 | 添加了 remotePatterns.search 属性。 |
v14.2.0 | 添加了 overrideSrc 属性。 |
v14.1.0 | getImageProps() 变为稳定版。 |
v14.0.0 | onLoadingComplete 属性和 domains 配置已弃用。 |
v13.4.14 | placeholder 属性支持 data:/image... |
v13.2.0 | 添加了 contentDispositionType 配置。 |
v13.0.6 | 添加了 ref 属性。 |
v13.0.0 | next/image 导入被重命名为 next/legacy/image 。next/future/image 导入被重命名为 next/image 。提供了一个 codemod 来安全自动地重命名导入。移除了 <span> 包装器。移除了 layout 、objectFit 、objectPosition 、lazyBoundary 、lazyRoot 属性。alt 现在是必需的。onLoadingComplete 接收对 img 元素的引用。移除了内置的加载器配置。 |
v12.3.0 | remotePatterns 和 unoptimized 配置变为稳定版。 |
v12.2.0 | 添加了实验性的 remotePatterns 和实验性的 unoptimized 配置。移除了 layout="raw" 。 |
v12.1.1 | 添加了 style 属性。添加了对 layout="raw" 的实验性支持。 |
v12.1.0 | 添加了 dangerouslyAllowSVG 和 contentSecurityPolicy 配置。 |
v12.0.9 | 添加了 lazyRoot 属性。 |
v12.0.0 | 添加了 formats 配置。添加了 AVIF 支持。 包装器从 <div> 改为 <span> 。 |
v11.1.0 | 添加了 onLoadingComplete 和 lazyBoundary 属性。 |
v11.0.0 | src 属性支持静态导入。添加了 placeholder 属性。添加了 blurDataURL 属性。 |
v10.0.5 | 添加了 loader 属性。 |
v10.0.1 | 添加了 layout 属性。 |
v10.0.0 | 引入了 next/image 。 |