npm install @daveyplate/next-page-title
First, you need to set up the PageTitleProvider
in your custom _app.js
file to provide the page title context to your application.
- Open your
_app.js
file. - Import the
PageTitleProvider
component. - Wrap your application with the
PageTitleProvider
. - (Optional) siteName is optional and falls back to process.env.NEXT_PUBLIC_SITE_NAME if not provided.
- (Optional) formatTitle prop allows you to change the title returned, works well for Translations.
// pages/_app.js
import { PageTitleProvider } from '@daveyplate/next-page-title'
function MyApp({ Component, pageProps }) {
return (
<PageTitleProvider siteName="YourSiteName">
<Component {...pageProps} />
</PageTitleProvider>
)
}
export default MyApp
To set a custom page title on a specific page, use the PageTitle
component.
- Open the page where you want to set a custom title (e.g.,
pages/about.js
). - Import the
PageTitle
component. - Use the
PageTitle
component and pass the desired title as a prop.
// pages/about.js
import { PageTitle } from '@daveyplate/next-page-title'
export default function AboutPage() {
return (
<>
<PageTitle title="About Us" />
<h1>About Us</h1>
<p>Welcome to the about page.</p>
</>
)
}
Now, when you navigate to the /about
page, the title of the page will be set to "About Us | YourSiteName".