自訂文件
自訂 Document
可用來更新渲染 頁面 時使用的 <html>
和 <body>
標籤。
要覆寫預設的 Document
,請按照以下方式建立 pages/_document
檔案:
須知事項
_document
僅在伺服器端渲染,因此無法在此檔案中使用像是onClick
這樣的事件處理器。- 頁面要正確渲染必須包含
<Html>
、<Head />
、<Main />
和<NextScript />
。
注意事項
_document
中使用的<Head />
元件與next/head
不同。此處的<Head />
元件應僅用於所有頁面共用的<head>
程式碼。對於其他情況(例如<title>
標籤),建議在頁面或元件中使用next/head
。<Main />
之外的 React 元件不會被瀏覽器初始化。請勿在此處添加應用程式邏輯或自訂 CSS(如styled-jsx
)。如果需要在所有頁面中共享元件(例如選單或工具列),請參閱 版面配置。Document
目前不支援 Next.js 的 資料獲取方法,例如getStaticProps
或getServerSideProps
。
自訂 renderPage
自訂 renderPage
屬於進階用法,僅在需要支援伺服器端渲染的函式庫(如 CSS-in-JS)時使用。內建的 styled-jsx
支援不需要此設定。
我們不建議使用此模式。 相反地,請考慮 逐步採用 App Router,它能更輕鬆地為 頁面和版面配置 獲取資料。
須知事項
_document
中的getInitialProps
不會在客戶端轉換時呼叫。_document
的ctx
物件等同於getInitialProps
接收的物件,並增加了renderPage
屬性。