Script
这个 API 参考将帮助你理解如何使用 Script 组件可用的属性。关于功能和用法,请参阅优化脚本页面。
import Script from 'next/script'
 
export default function Dashboard() {
  return (
    <>
      <Script src="https://example.com/script.js" />
    </>
  )
}Props
以下是 Script 组件可用属性的摘要:
| Prop | Example | Type | Required | 
|---|---|---|---|
| src | src="http://example.com/script" | String | 除非使用内联脚本,否则为必需 | 
| strategy | strategy="lazyOnload" | String | - | 
| onLoad | onLoad={onLoadFunc} | Function | - | 
| onReady | onReady={onReadyFunc} | Function | - | 
| onError | onError={onErrorFunc} | Function | - | 
Required Props
<Script /> 组件需要以下属性。
src
指定外部脚本 URL 的路径字符串。这可以是绝对外部 URL 或内部路径。除非使用内联脚本,否则 src 属性是必需的。
Optional Props
<Script /> 组件除了必需属性外,还接受许多其他属性。
strategy
脚本的加载策略。有四种不同的策略可以使用:
- beforeInteractive:在任何 Next.js 代码之前加载,并在任何页面水合作用发生之前加载。
- afterInteractive:(默认)在页面上发生一些水合作用之后提前加载。
- lazyOnload:在浏览器空闲时间期间加载。
- worker:(实验性)在 web worker 中加载。
beforeInteractive
使用 beforeInteractive 策略加载的脚本会被注入到服务器的初始 HTML 中,在任何 Next.js 模块之前下载,并按放置顺序执行。
使用此策略标记的脚本会在任何第一方代码之前被预加载和获取,但它们的执行不会阻止页面水合作用的发生。
beforeInteractive 脚本必须放在根布局(app/layout.tsx)中,并且设计用于加载整个站点所需的脚本(即,当应用程序中的任何页面已在服务器端加载时,脚本将加载)。
此策略应仅用于需要尽快获取的关键脚本。
import Script from 'next/script'
 
export default function RootLayout({
  children,
}: {
  children: React.ReactNode
}) {
  return (
    <html lang="en">
      <body>
        {children}
        <Script
          src="https://example.com/script.js"
          strategy="beforeInteractive"
        />
      </body>
    </html>
  )
}值得注意的是:带有
beforeInteractive的脚本将始终被注入到 HTML 文档的head中,无论它在组件中的放置位置如何。
一些应该使用 beforeInteractive 尽快获取的脚本示例包括:
- 机器人检测器
- Cookie 同意管理器
afterInteractive
使用 afterInteractive 策略的脚本会在客户端注入到 HTML 中,并在页面上发生一些(或全部)水合后加载。这是 Script 组件的默认策略,应该用于任何需要尽快加载但不需要在任何第一方 Next.js 代码之前加载的脚本。
afterInteractive 脚本可以放置在任何页面或布局中,并且只有在浏览器中打开该页面(或一组页面)时才会加载和执行。
import Script from 'next/script'
 
export default function Page() {
  return (
    <>
      <Script src="https://example.com/script.js" strategy="afterInteractive" />
    </>
  )
}一些适合 afterInteractive 的脚本示例包括:
- 标签管理器
- 分析工具
lazyOnload
使用 lazyOnload 策略的脚本在浏览器空闲时间在客户端注入到 HTML 中,并在页面上的所有资源获取后加载。这种策略应该用于任何不需要早期加载的后台或低优先级脚本。
lazyOnload 脚本可以放置在任何页面或布局中,并且只有在浏览器中打开该页面(或一组页面)时才会加载和执行。
import Script from 'next/script'
 
export default function Page() {
  return (
    <>
      <Script src="https://example.com/script.js" strategy="lazyOnload" />
    </>
  )
}不需要立即加载并可以使用 lazyOnload 获取的脚本示例包括:
- 聊天支持插件
- 社交媒体小部件
worker
警告:
worker策略尚未稳定,尚不适用于 App Router。请谨慎使用。
使用 worker 策略的脚本会卸载到 web worker 中,以释放主线程并确保只有关键的第一方资源在其上处理。虽然这种策略可以用于任何脚本,但这是一种高级用例,不能保证支持所有第三方脚本。
要使用 worker 作为策略,必须在 next.config.js 中启用 nextScriptWorkers 标志:
module.exports = {
  experimental: {
    nextScriptWorkers: true,
  },
}worker 脚本目前只能在 pages/ 目录中使用:
import Script from 'next/script'
 
export default function Home() {
  return (
    <>
      <Script src="https://example.com/script.js" strategy="worker" />
    </>
  )
}onLoad
警告:
onLoad尚不适用于 Server Components,只能在 Client Components 中使用。此外,onLoad不能与beforeInteractive一起使用 – 考虑使用onReady代替。
一些第三方脚本要求用户在脚本加载完成后运行 JavaScript 代码,以实例化内容或调用函数。如果你正在使用 afterInteractive 或 lazyOnload 作为加载策略加载脚本,你可以使用 onLoad 属性在加载后执行代码。
以下是仅在加载库后执行 lodash 方法的示例。
'use client'
 
import Script from 'next/script'
 
export default function Page() {
  return (
    <>
      <Script
        src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.20/lodash.min.js"
        onLoad={() => {
          console.log(_.sample([1, 2, 3, 4]))
        }}
      />
    </>
  )
}onReady
警告:
onReady尚不适用于 Server Components,只能在 Client Components 中使用。
一些第三方脚本要求用户在脚本加载完成后运行 JavaScript 代码,并在每次组件挂载时(例如,路由导航后)执行。你可以使用 onReady 属性在脚本首次加载时的加载事件后执行代码,然后在每次后续组件重新挂载后执行。
以下是每次组件挂载时如何重新实例化 Google Maps JS 嵌入的示例:
'use client'
 
import { useRef } from 'react'
import Script from 'next/script'
 
export default function Page() {
  const mapRef = useRef()
 
  return (
    <>
      <div ref={mapRef}></div>
      <Script
        id="google-maps"
        src="https://maps.googleapis.com/maps/api/js"
        onReady={() => {
          new google.maps.Map(mapRef.current, {
            center: { lat: -34.397, lng: 150.644 },
            zoom: 8,
          })
        }}
      />
    </>
  )
}onError
警告:
onError尚不适用于 Server Components,只能在 Client Components 中使用。onError不能与beforeInteractive加载策略一起使用。
有时捕获脚本加载失败是有帮助的。这些错误可以使用 onError 属性处理:
'use client'
 
import Script from 'next/script'
 
export default function Page() {
  return (
    <>
      <Script
        src="https://example.com/script.js"
        onError={(e: Error) => {
          console.error('Script failed to load', e)
        }}
      />
    </>
  )
}版本历史
| 版本 | 变更 | 
|---|---|
| v13.0.0 | 修改 beforeInteractive和afterInteractive以支持app。 | 
| v12.2.4 | 添加 onReady属性。 | 
| v12.2.2 | 允许在 _document中放置带有beforeInteractive的next/script。 | 
| v11.0.0 | 引入 next/script。 |