Aimed at modules like @next/mdx, which adds support for pages ending with .mdx
. You can configure the extensions looked for in the pages
directory when resolving pages.
Open next.config.js
and add the pageExtensions
config:
module.exports = {
pageExtensions: ['mdx', 'md', 'jsx', 'js', 'tsx', 'ts'],
}
Note: The default value of
pageExtensions
is['tsx', 'ts', 'jsx', 'js']
.
Note: configuring
pageExtensions
also affects_document.js
,_app.js
,_middleware.js
as well as files underpages/api/
. For example, settingpageExtensions: ['page.tsx', 'page.ts']
means the following files:_document.tsx
,_app.tsx
,_middleware.ts
,pages/users.tsx
andpages/api/users.ts
will have to be renamed to_document.page.tsx
,_app.page.tsx
,_middleware.page.ts
,pages/users.page.tsx
andpages/api/users.page.ts
respectively.
pages
directoryTo colocate test files, generated files, or other files used by components in the pages
directory, you can prefix the extensions with something like page
.
Open next.config.js
and add the pageExtensions
config:
module.exports = {
pageExtensions: ['page.tsx', 'page.ts', 'page.jsx', 'page.js'],
}
Then rename your pages to have a file extension that includes .page
(ex. rename MyPage.tsx
to MyPage.page.tsx
).
Note: Make sure you also rename
_document.js
,_app.js
,_middleware.js
, as well as files underpages/api/
.
Without this config, Next.js assumes every tsx/ts/jsx/js file in the pages
directory is a page or API route, and may expose unintended routes vulnerable to denial of service attacks, or throw an error like the following when building the production bundle:
Build error occurred
Error: Build optimization failed: found pages without a React Component as default export in
pages/MyPage.generated
pages/MyPage.test
See https://nextjs.org/docs/messages/page-without-valid-component for more info.