| dashboard-app-course | ||
| docs | ||
| my-app | ||
| react-foundations-course | ||
| README.md | ||
Next.js
A place for me to learn Next.js
Next.js is developed & maintained by Vercel
Installation (macOS)
Requirements:
- Homebrew already installed
Install nodejs
brew install node@22
Check node version
node -v
Check NPM version
npm -v
If you get some errors:
brew cleanup
Then try again
Create new project
npx create-next-app@latest
Afterwards some questions about the project will be asked. You can leave the settings as default.
Upgrade to newer Next.js version
npx @next/codemod@canary upgrade latest
Run development server
npm run dev
Afterwards the site can be accessed in the browser at http://localhost:3000.

General structure
The whole app is organzied in multiple folders. THe typescript files for the app are stored in src/app.
The code is written in TypeScript.
In package.json are the dependencies saved. The Next.js configuration is saved in next.config.ts.
Each folder in app represents a route of the application, but its only accessable when a page.js or route.js file is contained.
When a folder is named with _ as prefix, it will be ignored by the routing and not accessable from within the application.
Folders in parenthesis (Klammern) while not be show in the route. (https://nextjs.org/docs/app/getting-started/project-structure#organize-routes-without-affecting-the-url-path)
Slugs can be defined by creating a folder in brackets [] like [slug].
Basic tutorial: https://www.youtube.com/watch?v=__mSgDEOyv8
By default the code is executed on the server. When you want to change this behavior the following has to be added to the top of the file:
'use client';
Its possible to render the most parts of an app on the server and some components, like the hover state of the navbar, on the client. Depending on what makes most sense for the application. Thoose components should be move to a separated JS or JSX file.
The main function of the app or just a file is defined by export default.
The layout of the app is defined in layout.js. The content of layout.js is shared between all pages.
Styling
In global.css some global CSS styling rules were defined. Usally this file is imported in the root layout of the app layout.js/layout.jsx/layout.tsx.
Commonly TailwindCSS is used with Next.js for easier stylings. This can be recognized in the beginning of the global.css-File:
@tailwind base;
@tailwind components;
@tailwind utilities;
As an alternative to TailwindCSS also CSS modules can be used for styling. There you would create a own CSS file for every component which needs styling and only import those into the project. More details about that can be found in the Next.js docs.
Additionaly there are other, less popular methods for styling your Next.js app like Sass or CSS-in-JS libraries. And, because in the end just normal CSS is rendered, you can use any styling solution you want/already know too with Next.js.
TailwindCSS
Tailwind is a CSS framework, which enables you to style the whole website without ever leaving the HTML or Next.js code. You never have to touch a CSS file. All styling is done via predefined CSS classes.
When using VScode as Editor the Tailwind CSS IntelliSense should be installed. It enables autofill for Tailwind css classes aund adds preview of the css behind a class when hovering over it. It improves the development process with TailwindCSS a lot.
The styling is applied when adding a css class to an HTML object.
<div className="fixed top-0"></div>
When non existing tailwind class matches the value you need, a custom value can be assigend, which will automatically be generated by tailwind on build.
<div className="top-[-27px]"></div>
Common classes
| class | what it does |
|---|---|
| top-0 | top: 0; |
| left-0 | left: 0; |
| w-0 | width |
| h-0 | height |
| m-0 | margin |
| mx-auto | margin-inline: auto; |
| p-0 | padding |
| flex | display: flex; |
| h-screen | 100vh; -> viewport height |
| bg-gray-900 | background-color |
| text-white | text color |
| shadow-lg | adds a nice shadow (different variantes are available) |
| rounded-3xl | border-radius |
| transition-all | add a transition to every property that changes |
| hover: | Adds class on hover state |
| group | defines a parent element for a group |
| group-hover: | adds a class on hover over the parent of the group |
| dark: | only apply styling in dark mode |
| md: | media query for desktop devices |
| hidden | display: none; |
| block | display: block; |
Tailwind uses a custom spacing scale. The translation table can be found here.
To specify a hover state in tailwind just add a prefix of hover: in front of the styling class.
<div className="hover:bg-green-600 hover:text-white"></div>
When having a lot of styling on a element it can make sense to create a custom css class combining thoose tailwind classes. This can be done by adding the following to globals.css:
@layer components{
.sidebar-icon{
@apply relative flex items-center justify-center
h-12 w-12 mt-2 mb-2 mx-auto shadow-lg
bg-gray-800 text-green-400
hover:bg-green-600 hover:text-white;
}
/* more custom classes... */
}
With @apply other css classes can be applied to an element.
With a group in tailwind its possible to change the state of an child based on the parent like on hover over the parent. But groups don't work when using @apply in css.
The class group has to be added to the parent element. Then a connected hover action can be added to the child via group-hover:<CLASS>.
Example:
<div className="sidebar-icon group">
{icon}
<span className="sidebar-tooltip group-hover:scale-100">
{text}
</span>
</div>
Clsx
clsx is a library which adds the possibility to toggle css classes based on JS conditions. This is useful to change a styling depending on the value of a state.
React Icons
React Icons is a easy way to import the most popular icons into a react project.
It can be installed via npm.
npm install react-icons --save
Now the icons can be used after importing them. Each icon is a custom react component.
import { FaPlay } from "react-icons/fa";
<FaPlay />
Fonts
Fonts are managed in the file /app/ui/fonts.ts. Next.js is be default able to import fonts from Google Fonts. After importing a font the subset has to be defined. In my case its the latin subset.
import { Inter } from 'next/font/google';
export const inter = Inter({subsets: ['latin'], weight: ['400', '700']});
Afterwards the font can be added to the layout.tsx so its visible all over the application.
There also a className has to be added to the body, so that the font will be rendered.
import {inter} from '@/app/ui/fonts';
export default function RootLayout({
children,
}: {
children: React.ReactNode;
}) {
return (
<html lang="en">
<body className={`${inter.className} antialiased`}>{children}</body>
</html>
);
}
The same way other fonts can be imported and also just applied on single objects.
Images
Next.js comes with a built-in image component, which does many image optimizations like serving images as webp or avif where possible, automatically.
The componennt is called <Image>.
Example usage:
import Image from 'next/image';
export default function Page() {
return (
<Image
src="/hero-desktop.png"
width={1000}
height={760}
className="block"
alt="just an example"
/>
);
}
The width and height should be specified to prevent layout shift - the values set are just used for defining the right aspect ratio - Next.js decides by itself which size has to be rendered.