Home / Blog / News / Mastering Full-Stack Nuxt with Nitro and h3 – Insights from Alexander Lichter’s Nuxt Nation 2024 Talk
Mastering Full-Stack Nuxt with Nitro and h3 – Insights from Alexander Lichter’s Nuxt Nation 2024 Talk

Mastering Full-Stack Nuxt with Nitro and h3 – Insights from Alexander Lichter’s Nuxt Nation 2024 Talk

Eleftheria Batsou
Eleftheria Batsou
Updated: December 5th 2024
This entry is part 2 of 5 in the series Nuxt Nation 2024 Talks

Introduction

Alexander Lichter's session at Nuxt Nation 2024, titled "Nuxt, Nitro and h3 in Practice - Unleash the Full Stack Beast," provided a deep dive into the server-side capabilities of Nuxt.js. This article captures the essence of his talk, focusing on how developers can harness the power of Nitro and h3 to build robust full-stack applications, even if they initially approach Nuxt from a front-end perspective.

Nuxt Nation X

Understanding Nuxt's Ecosystem

Nuxt.js is celebrated for its ease in building server-rendered Vue.js applications, but its ecosystem, including Nitro and h3, offers much more:

  • Nitro: Described by Alexander as a server meta-framework, Nitro is not just another server but a comprehensive solution that integrates with various runtimes and provides deployment presets, making it ideal for full-stack development.
    "Nitro is a server meta framework that integrates an HTTP framework with a lot of other things." ~ Alexander**
  • h3: Positioned as a modern alternative to frameworks like Express, h3 is an HTTP framework built to work seamlessly with Nitro, offering a composable approach to handling server requests.

Nitro: The Server Meta Framework

Nitro is a server meta framework that integrates an HTTP framework with various other packages, making it a powerful tool for developers. It is often compared to frameworks like Fastify or Express, but Nitro offers much more functionality. It is designed to facilitate full-stack development, allowing developers to connect with other tools and frameworks seamlessly.

One of the key features of Nitro is its runtime agnosticism, meaning it can operate across different environments, such as Cloudflare Workers or a personal VPS. This flexibility extends to static site generation and pre-rendering, making deployment straightforward and efficient.

Nitro also includes experimental features, such as the tasks API and database connections through packages like DB0. While labeled as experimental, these features are stable and allow for feedback and potential API changes without necessitating a major version update. Developers are encouraged to pin their versions for larger projects to maintain stability.

Importantly, Nitro can be used independently, which is a significant advantage. While it powers many meta frameworks, including discussions around its use in Angular, developers can also utilize Nitro to create APIs in various runtimes, including Deno and Node.js, using JavaScript or TypeScript.

Exploring h3: The HTTP Web Framework

h3 is a modern HTTP web framework that serves as a crucial component of Nitro. It can be likened to Express, but with a more contemporary approach. While Nitro operates at a higher level, providing various features and integrations, h3 functions as a foundational layer, offering a minimalistic alternative for developers who may not require the full suite of Nitro's capabilities.

One of the key advantages of h3 is its runtime agnosticism, allowing it to be utilized independently of Nitro. This flexibility makes it an appealing choice for those seeking a lightweight solution. Additionally, h3 is designed to be composable, enabling developers to structure their requests similarly to how they would with the Composition API in Vue, but applied to backend development.

Performance is another strong suit of h3, as it is known for its speed and efficiency. It is also tree-shakable, which contributes to its lightweight nature. Benchmarks from the Fastify repository illustrate h3's competitive performance compared to other frameworks like Koa and Express, although it's important to note that benchmarks often reflect hypothetical scenarios. In real-world applications, factors such as database calls and API interactions typically serve as the primary bottlenecks, rather than the server framework itself.

Overall, h3 stands out as a powerful and efficient HTTP web framework that can be used both as part of Nitro and as a standalone solution for developers looking for a modern, fast, and composable option.

Integration of Nuxt, Nitro, and h3

Alexander also explored in his talk how Nuxt, Nitro, and h3 work together to enhance web application development. Nuxt serves as the framework that integrates with Nitro, which is responsible for server-side functionalities, while h3 acts as the HTTP web framework within Nitro.

The relationship between these components is crucial, as they complement each other in various scenarios. For instance, when querying an API route from Nitro, such as /api/test, the response is handled directly by Nitro without initiating the Nuxt application. Conversely, when navigating within the Nuxt application, such as moving from one route to another, the client-side navigation is managed by Nuxt, with potential API calls to Nitro for data retrieval.

A significant aspect of this integration is the intersection where Nuxt performs Server-Side Rendering (SSR). SSR encompasses not only traditional server rendering but also static site generation and pre-rendering. This means that during the build process, pages can be rendered ahead of time, or a server can dynamically render pages as they are requested. Even in Single Page Applications (SPAs), Nitro can execute middleware when a server is running, showcasing the flexibility and synergy between these technologies.

Live Coding: Building with Nuxt and Nitro

In this section, we will go through the process of building a simple application using Nuxt and Nitro. The following steps outline the key tasks involved:

  1. Setting Up a Basic Nuxt Application
  • Start by creating a new Nuxt application. Open your application and check the default view. You should see a minimal setup with the Nuxt configuration.
  • Ensure that the compatibility version is set to 4, and enable DevTools for easier debugging.
  1. Creating API Endpoints with Nitro
  • Create a new file named api/test.js to set up a basic API endpoint. Use the Nitro event handler to return a simple JSON response:

    export default defineEventHandler(() => {
        return { data: 'okay' };
    });
  • Test the endpoint by navigating to /api/test in your browser. You should see the JSON response.

  1. Fetching Data from External APIs
  • To fetch data from an external API, you can use the fetch function. For example, this is what you can do with “icanhazdadjoke”:

    const response = await fetch('https://icanhazdadjoke.com/', {
        headers: { 'Accept': 'application/json' }
    });
    const data = await response.json();
    return data;
  • Make sure to handle the response correctly and display it in your application.

  1. Implementing Caching and Storage Solutions
  • To store the jokes and manage recent jokes, you can use the unstorage package integrated with Nitro. Set up a storage instance and save the jokes:

    const storage = useStorage();
    await storage.setItem('recentJokes', joke);
    
  • Implement logic to manage the number of stored jokes, ensuring that you do not exceed a certain limit (e.g., 10 jokes).

By following these steps, you will have a basic Nuxt application that can fetch jokes from an external API, store them, and display them in your application. This live coding session demonstrates the power of Nuxt and Nitro in building modern web applications.

Performance Considerations and Best Practices

Let’s explore key performance considerations and best practices when using the Nitro and Nuxt combination, particularly in production environments.

Key Trade-offs When Enabling Server-side Functionality

When enabling server-side functionality with Nitro, developers should be aware of the added complexity in server rendering. For instance, if you have a Single Page Application (SPA), all API requests must be handled on the client side, which can lead to unnecessary data fetching. By leveraging server-side capabilities, you can optimize data retrieval and only send the necessary information to the client, enhancing performance.

Scalability and Performance Tips

  • Production Considerations: Nitro has shown impressive scalability, with high requests per second compared to other frameworks. This makes it suitable for production use
  • Caching and Rate Limiting: Effective caching strategies and external solutions for rate limiting were suggested to manage server load and ensure performance without impacting other app functionalities.

Common Pitfalls in Route Rules and Caching

When configuring route rules in Nuxt, it's crucial to understand that only the initial request is cached. If a user navigates back to a cached page, they may encounter outdated content if the underlying data has changed. To mitigate this, it's advisable to cache API calls to maintain consistency between the initial page state and subsequent navigations.

Additionally, when implementing server-side caching, it should enhance page speed rather than hinder it. Using tools like the define cache event handler can help manage caching effectively without slowing down other parts of the application.

Conclusion and Q&A

Alexander Lichter's talk at Nuxt Nation 2024 was a testament to the robust full-stack capabilities of Nuxt.js when combined with Nitro and h3. This session equipped developers with the knowledge to expand their Nuxt projects beyond client-side rendering, exploring server-side operations that can significantly enhance the application's functionality, security, and performance.

For developers interested in building full-stack applications with a modern framework, this presentation offered both inspiration and practical guidance on leveraging Nuxt's server ecosystem.

Interested in learning more about Nitro? Check out this 2-hour course by Vue School.

Related Courses

Start learning Vue.js for free

Eleftheria Batsou
Eleftheria Batsou
Is a passionate community manager with a coding background, keen on UX research and public speaking. She has been working in the field of tech since 2017. She likes researching and getting to know how things started or how she could improve them! She likes learning and sharing her knowledge about development/research/design and visual arts.

Comments

Latest Vue School Articles

The Human Side of Vue.js: How Learning Vue Changes Your Life as a Developer

The Human Side of Vue.js: How Learning Vue Changes Your Life as a Developer

Explore how learning Vue.js can transform your career and personal development. From career growth to community involvement, discover the human side of coding with Vue.
Eleftheria Batsou
Eleftheria Batsou
Why you should attend Vue.js Nation 2025

Why you should attend Vue.js Nation 2025

Don't miss Vue.js Nation 2025 event! Join Evan You and top experts online, free, January 29-30. Essential for Vue.js developers.
Eleftheria Batsou
Eleftheria Batsou

Our goal is to be the number one source of Vue.js knowledge for all skill levels. We offer the knowledge of our industry leaders through awesome video courses for a ridiculously low price.

More than 200.000 users have already joined us. You are welcome too!

Follow us on Social

© All rights reserved. Made with ❤️ by BitterBrains, Inc.