Introduction
Next.js is a Framework which build above React.js, Next.js Team called it The React Framework for Production, Which let you optimize your React Applications throw SSG, ISR and SSR Strategies.
In this Article we will know wthat is Difference between _app.js and _document.js files in Next.js.
So let's get started... ๐
_app.js File
When You create a new Next.js Project you will notice that there is a file in the pages directory called _app.js
and if you open it you will see the following code:
import '../styles/globals.css'
import type { AppProps } from 'next/app'
function MyApp({ Component, pageProps }: AppProps) {
return <Component {...pageProps} />
}
export default MyApp
You can name the app.js file as the Root of all Components in your Next App, Which Means that Every Page that you will create in the pages directory will move to throw the MyApp Component.
This is a beautiful Feature:
Which let you add a Global Layout Component on all Your Project Pages like Navbars and Footers...etc
You Can Also add Your Basic Meta Tags to All Pages throw Head Component.
_document.js File
This file is unknown to a lot of Next.js Developers unlike the _app.js file which is famous, And This is due to its low use In addition You should create it to use It.
_document.js file lets you Overwrite the Basic HTML structure on Your Next App.
Let's See How...
Create an js File on Pages Directory and name is as "_document.js" and Put the following Code in It:
import Document, { Html, Main, Head, NextScript } from "next/document";
class MyDocument extends Document {
render() {
return (
<Html>
<Head />
<body>
<Main />
<NextScript />
</body>
</Html>
);
}
}
export default MyDocument;
This is the Default Structure for HTML in Your App, Now you can Edit It like add the lang
Attribute to html
tag and more.
โ๏ธNotice that
- _document.js lets you edit only html code structure which means that you can't add javascript events in it.
Head
Component in _document.js is Completely different from Head in _app.js file
Conclusion
Use _app.js file when you need to add some Global Layout or Meta Tags And use the _document.js file only if you need to edit the basic structure of your HTML Code.
Top comments (0)