Skip to content

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="作者的照片" />
}

参考

属性

以下属性可用:

属性示例类型状态
srcsrc="/profile.png"String必填
altalt="作者的照片"String必填
widthwidth={500}Integer (px)-
heightheight={500}Integer (px)-
fillfill={true}Boolean-
loaderloader={imageLoader}Function-
sizessizes="(max-width: 768px) 100vw, 33vw"String-
qualityquality={80}Integer (100)-
prioritypriority={true}Boolean-
placeholderplaceholder="blur"String-
stylestyle='{\{margin: 10px}\}'Object-
onLoadingCompleteonLoadingComplete={img => done()}Function已弃用
onLoadonLoad={event => done()}Function-
onErroronError={event => fail()}Function-
loadingloading="lazy"String-
blurDataURLblurDataURL=""
        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 才允许被使用。更宽松的设置是仅提供 protocolhostname,让 pathname 为空,这将允许任何路径。

下面是 remotePatterns 配置的完整内容,可用于限制外部 URL:

  • protocol:允许的协议:httphttps
  • hostname:允许的主机名。
  • port:允许的端口。
  • pathname:允许的路径模式。必须以 / 开头。
    • 使用 /** 允许任何路径。
    • 使用 /foo/** 允许任何以 /foo/ 开头的路径。
    • 使用 /foo/bar 只允许确切的 /foo/bar 路径。
    • 默认情况下要求路径和参数精确匹配。

须知:在 Next.js 13.4.0 及之后,不再支持 domains,因为它缺乏与 remotePatterns 相同的安全约束。我们强烈建议使用 remotePatterns 代替,它更安全。

加载器

如果你想要使用云提供商优化图像,而不是使用 Next.js 内置的图像优化 API,你可以在 next.config.js 中配置 loaderloaderFile

以下 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 时,总是检查 widthquality 和其他支持的参数是否正确传递。例如,你可能想要改变 quality 参数来匹配你的自定义 API。

设备尺寸

如果你知道用户的设备宽度,你可以在 next.config.js 中设置 deviceSizes 属性。这些宽度会与 sizes 属性一起使用,以确定最佳的图像尺寸。

如果没有提供 sizes 属性,则会使用 layout='responsive'layout='fill' 以确定所需的图像宽度。

如果 deviceSizesimageSizes 数组的长度大于 25,则 Image 优化的开发构建将会失败。

图像尺寸

你可以在 next.config.js 中设置 imageSizes 属性。当 sizes 属性用于描述小于最小设备宽度的图像宽度时,这些宽度会与 deviceSizes 结合使用。

如果没有提供 sizes 属性,则会使用 layout='fixed'layout='intrinsic' 以确定所需的图像宽度。

使用 width 属性的图像将使用 deviceSizesimageSizes 的结合来查找最接近的匹配。

接受的格式

默认的 接受 头将包括:image/webp

您可以通过设置 next.config.js 中的 formats 数组来配置接受的优化格式:

jsx
module.exports = {
  images: {
    formats: ['image/avif', 'image/webp'],
  },
}

目前支持的格式有 image/avifimage/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.0remotePatterns 增加了对 URL 对象数组的支持。
v15.0.0contentDispositionType 配置默认值改为 attachment
v14.2.23添加了 qualities 配置。
v14.2.15添加了 decoding 属性和 localPatterns 配置。
v14.2.14添加了 remotePatterns.search 属性。
v14.2.0添加了 overrideSrc 属性。
v14.1.0getImageProps() 变为稳定版。
v14.0.0onLoadingComplete 属性和 domains 配置已弃用。
v13.4.14placeholder 属性支持 data:/image...
v13.2.0添加了 contentDispositionType 配置。
v13.0.6添加了 ref 属性。
v13.0.0next/image 导入被重命名为 next/legacy/imagenext/future/image 导入被重命名为 next/image。提供了一个 codemod 来安全自动地重命名导入。移除了 <span> 包装器。移除了 layoutobjectFitobjectPositionlazyBoundarylazyRoot 属性。alt 现在是必需的。onLoadingComplete 接收对 img 元素的引用。移除了内置的加载器配置。
v12.3.0remotePatternsunoptimized 配置变为稳定版。
v12.2.0添加了实验性的 remotePatterns 和实验性的 unoptimized 配置。移除了 layout="raw"
v12.1.1添加了 style 属性。添加了对 layout="raw" 的实验性支持。
v12.1.0添加了 dangerouslyAllowSVGcontentSecurityPolicy 配置。
v12.0.9添加了 lazyRoot 属性。
v12.0.0添加了 formats 配置。
添加了 AVIF 支持。
包装器从 <div> 改为 <span>
v11.1.0添加了 onLoadingCompletelazyBoundary 属性。
v11.0.0src 属性支持静态导入。
添加了 placeholder 属性。
添加了 blurDataURL 属性。
v10.0.5添加了 loader 属性。
v10.0.1添加了 layout 属性。
v10.0.0引入了 next/image

🎉有任何问题,欢迎联系我

WeChat QR Code
WeChat
QQ QR Code
QQ

赣ICP备2023003243号