This is a solution to the Recipe page challenge on Frontend Mentor. Frontend Mentor challenges help you improve your coding skills by building realistic projects.
Users should be able to:
- View the optimal layout depending on their device's screen size
- Solution URL: [https://www.frontendmentor.io/solutions/recipe-page-with-nextjs-tailwind-css-jGP0-AZI5R]
- Live Site URL: [https://recipe-page-nine-pi.vercel.app/]
To get a local copy up and running follow these simple steps:
Make sure you have the following software installed on your machine:
-
Clone the repository:
git clone https://github.com/jaceleedev/recipe-page.git
-
Navigate to the project directory:
cd recipe-page
-
Install dependencies using pnpm:
pnpm install
-
Start the development server:
pnpm dev
-
Open your browser and visit http://localhost:3000 to view the project.
- Next.js (v14.2.5)
- TypeScript (v5)
- Tailwind CSS (v3.4.1)
- CSS Grid
- Semantic HTML5 markup
- SEO & web accessibility
During this project, I learned about the potential performance issues of overusing @apply in CSS Modules with Tailwind CSS, especially in large-scale projects. Initially, I used @apply in CSS Modules for better readability:
.button {
@apply py-2 px-4 bg-blue-500 text-white rounded hover:bg-blue-600;
}
However, I discovered that excessive use of @apply can lead to performance degradation in larger projects. Instead, I adopted the approach of using Tailwind classes directly in components:
function Button() {
return (
<button className="py-2 px-4 bg-blue-500 text-white rounded hover:bg-blue-600">
Click me
</button>
);
}
This approach maintains the advantages of Tailwind CSS, such as easier maintenance and smaller CSS bundle sizes.
While Tailwind CSS is powerful, there may be situations where it's challenging to achieve complex designs solely with utility classes. In such cases, I'll consider using CSS Modules for more fine-grained control over styles. Additionally, I want to improve the readability of my components by creating smaller, reusable components for elements that are used frequently. This aligns with the Tailwind CSS documentation's recommendation:
function PrimaryButton({ children }) {
return (
<button className="py-2 px-4 bg-blue-500 text-white rounded hover:bg-blue-600">
{children}
</button>
);
}
// Usage
<PrimaryButton>Click me</PrimaryButton>;
This approach will help maintain cleaner and more manageable code in larger projects.
- Next.js Documentation - Comprehensive guide to Next.js features and API.
- Tailwind CSS Documentation - Detailed documentation for Tailwind CSS.
- A Complete Guide to CSS Grid - Comprehensive guide to CSS Grid.
- GitHub - @jaceleedev
- Frontend Mentor - @jaceleedev