basePath
ドメインのサブパスで Next.js アプリケーションをデプロイするには、basePath
設定オプションを使用できます。
basePath
を使用すると、アプリケーションのパスプレフィックスを設定できます。たとえば、''
(空の文字列、デフォルト) の代わりに /docs
を使用するには、next.config.js
を開き、basePath
設定を追加します。
next.config.js
module.exports = {
basePath: '/docs',
}
知っておくと便利: この値はビルド時に設定する必要があり、クライアント側のバンドルにインライン化されるため、再構築なしに変更することはできません。
リンク
next/link
および next/router
を使用して他のページにリンクする場合、basePath
が自動的に適用されます。
たとえば、/about
を使用すると、basePath
が /docs
に設定されている場合、自動的に /docs/about
になります。
export default function HomePage() {
return (
<>
<Link href="/about">About Page</Link>
</>
)
}
出力 html
<a href="/docs/about">About Page</a>
これにより、basePath
値を変更するときに、アプリケーション内のすべてのリンクを変更する必要がなくなります。
画像
next/image
コンポーネントを使用する場合、src
の前に basePath
を追加する必要があります。
たとえば、/docs/me.png
を使用すると、basePath
が /docs
に設定されている場合、画像が正しく提供されます。
import Image from 'next/image'
function Home() {
return (
<>
<h1>My Homepage</h1>
<Image
src="/docs/me.png"
alt="Picture of the author"
width={500}
height={500}
/>
<p>Welcome to my homepage!</p>
</>
)
}
export default Home
このページは役に立ちましたか?