Astro – Island Technology in the Name of Optimization

Rate this content
Bookmark

Next.js is the default choice for most teams, although there are many other solutions on the market. One of such solutions is Astro, which in certain areas, due to its eccentric approach, seems to outclass the Vercel king. During this lecture, I will present the key features of Astro, as well as the differences between it and the aforementioned Next.js. You will learn what interactive islands are, why MPA (multi-page application) is still a very good choice for content-driven websites, and much more. Who knows - maybe you will use Astro in your next project?

This talk has been presented at React Advanced 2024, check out the latest edition of this React Conference.

FAQ

ASTRA allows easy integration with UI libraries like React, Vue, and Tailwind. Developers can add these libraries to their projects with minimal configuration, maintaining a balance between simplicity and the use of preferred tools.

The View Transitions API allows for smooth animations during page transitions in multi-page applications. ASTRA supports this API, enabling rich animations and enhancing user experience across different browsers.

ASTRA is designed to minimize JavaScript sent to the client, resulting in faster load times and a more responsive user experience. It addresses performance issues by focusing on efficient content delivery and reducing unnecessary JavaScript.

ASTRA's server islands allow for server-rendered components within static pages, providing flexibility across hosting environments without relying on cloud-specific features. This enables easy deployment and maintains performance without complex configurations.

ASTRA balances performance and flexibility by allowing developers to create static websites without JavaScript by default, while providing selective hydration for adding interactivity only when needed. This approach optimizes speed and maintains flexibility.

ASTRA components are executed on the server side by default, sending no JavaScript to the client unless specified. This improves performance by reducing client-side JavaScript load, while allowing dynamic content generation through server-side variables.

ASTRA is a powerful tool in modern web development that optimizes content delivery while providing the flexibility of modern JavaScript frameworks. It allows for creating fast static websites with selective JavaScript loading for interactivity.

ASTRA is particularly well-suited for content-driven projects like blogs, portfolios, and corporate websites where fast content delivery and performance are priorities. It's also ideal for online stores, creative portfolios, and marketing landing pages.

ASTRA uses file-based routing where the project's pages directory structure reflects site URLs. It supports dynamic routes and can handle complex content hierarchies using fallback paths. It allows building pages with ASTRA components, HTML, Markdown, or MDX.

ASTRA is unique because it focuses on minimizing JavaScript load by delivering pure HTML by default and providing flexibility for adding interactivity. It's simpler and more performant for static content compared to more complex frameworks like Next.js or Remix.

Szymon Chmal
Szymon Chmal
20 min
28 Oct, 2024

Comments

Sign in or register to post your comment.
Video Summary and Transcription
Hello everyone. My name is Szymon Chmal and I am a Senior React Native Developer at CallStack. Today I'm going to introduce you to ASTRA, a powerful tool in modern web development that optimizes content delivery while providing the flexibility of modern JavaScript frameworks. ASTRA allows you to create blazing fast static websites without needing any JavaScript by default. It's perfect for sites that are mostly static but have a few interactive features. ASTRA is trusted by industry leaders like Microsoft and Porsche. It's built with content-driven pages in mind and supports integration with popular UI libraries like React, Vue, and Tailwind. ASTRA keeps things simple with file-based routing.

1. Introduction to ASTRA

Short description:

Hello everyone. My name is Szymon Chmal and I am a Senior React Native Developer at CallStack. Today I'm going to introduce you to ASTRA, a powerful tool in modern web development that optimizes content delivery while providing the flexibility of modern JavaScript frameworks. ASTRA allows you to create blazing fast static websites without needing any JavaScript by default. It's perfect for sites that are mostly static but have a few interactive features. ASTRA is trusted by industry leaders like Microsoft and Porsche. It's built with content-driven pages in mind and supports integration with popular UI libraries like React, Vue, and Tailwind. ASTRA keeps things simple with file-based routing.

Hello everyone. Welcome and thank you for joining today. My name is Szymon Chmal and I am a Senior React Native Developer at CallStack. Today I'm going to introduce you to a powerful tool in modern web development called ASTRA. We'll explore how it optimizes content delivery while providing the flexibility of modern JavaScript frameworks. Whether you're building interactive applications or static, content-driven sites, ASTRA might be the solution you've been looking for.

So let's get right into it. We have all come across different types of web experiences. On one hand, we have highly interactive applications and on the other hand, sites that are mostly static and just serve content. The question is, how do you find the right balance between overloading the browser with JavaScript and keeping things fast? Let's talk about what choices we have in the current ecosystem.

Right now, we have a few well-known options for building web applications. You've got full-featured frameworks like Next.js or Remix that are great for highly interactive applications but they can sometimes feel like overkill for static sites. Then there is Gatsby, which had its moment but learning it can be a bit much. And let's be honest, it feels kind of abandoned these days. And then we've got classic static site generators like Jackal, which work perfectly until you need to add any interactive elements. So what if we need both speed and flexibility? That's the place where ASTRA steps in because it allows you to create blazing fast static websites without needing any JavaScript by default. But what makes it really stand out is that you can still sprinkle in interactivity with selective hydration, meaning you only load JavaScript when it's absolutely needed. This approach is perfect for sites that are mostly static but have a few interactive features. It gives you the best of both worlds, performance and flexibility.

And as we can see, ASTRA isn't exactly a newcomer in the world of web development. In fact, it's already been trusted by some of the biggest names in the industry. For example, companies like Microsoft and Porsche have used ASTRA to build their websites, which speaks volumes about its reliability and performance. So what makes ASTRA unique? First of all, it's built with content-driven pages in mind, perfect for blogs, portfolios or corporate websites that don't need tons of JavaScript to work. You can still use your favorite UI libraries like React, Vue or SWAT, but ASTRA takes care of delivering pure HTML by default. It also embraces multi-page application architecture, meaning each interaction results in a full page reload, which is often faster and simpler for mostly static content. It's all about reducing JavaScript load while giving you the flexibility to add dynamic elements when needed. And one of the best things about ASTRA is how flexible it is when it comes to integrating libraries. Whenever you're a fan of React, Solids, maybe Vue, or you're just low-working with Tailwind, ASTRA has got you covered, because with just a few commands you can easily add those libraries to your project without needing to reconfigure everything. That gives you the freedom to use the tools you love without sacrificing the simplicity and speed that ASTRA brings to the table. ASTRA keeps things simple with file-based routing.

2. ASTRA: Dynamic Routes and Component-based Pages

Short description:

ASTRA allows you to create dynamic routes and build pages with components using various languages. This keeps your workflow clean and efficient, allowing you to focus on your content.

This means the structure of your project's sources pages directory directly reflects the URLs of your site. So for example, if you create an about-me.astra file in the pages folder, it automatically becomes accessible at mysite.com about-me. But it doesn't stop there. ASTRA also supports dynamic routes, which are useful for creating pages on the fly. For instance, a file named slug.astra in the blog directory could generate a unique URL for each blog post based on its slug. You can also use fallback paths with a structure like ...path.astra to catch multiple variations of a route, which is great for handling complex content hierarchies. And what's best, you can build pages with ASTRA components, HTML, Markdown, or, for example, MDX. This approach keeps your workflow clean and efficient, allowing you to focus on what truly matters, your content.

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

Building Better Websites with Remix
React Summit Remote Edition 2021React Summit Remote Edition 2021
33 min
Building Better Websites with Remix
Top Content
Remix is a web framework built on React Router that focuses on web fundamentals, accessibility, performance, and flexibility. It delivers real HTML and SEO benefits, and allows for automatic updating of meta tags and styles. It provides features like login functionality, session management, and error handling. Remix is a server-rendered framework that can enhance sites with JavaScript but doesn't require it for basic functionality. It aims to create quality HTML-driven documents and is flexible for use with different web technologies and stacks.
Speeding Up Your React App With Less JavaScript
React Summit 2023React Summit 2023
32 min
Speeding Up Your React App With Less JavaScript
Top Content
Watch video: Speeding Up Your React App With Less JavaScript
Mishko, the creator of Angular and AngularJS, discusses the challenges of website performance and JavaScript hydration. He explains the differences between client-side and server-side rendering and introduces Quik as a solution for efficient component hydration. Mishko demonstrates examples of state management and intercommunication using Quik. He highlights the performance benefits of using Quik with React and emphasizes the importance of reducing JavaScript size for better performance. Finally, he mentions the use of QUIC in both MPA and SPA applications for improved startup performance.
Full Stack Documentation
JSNation 2022JSNation 2022
28 min
Full Stack Documentation
Top Content
The Talk discusses the shift to full-stack frameworks and the challenges of full-stack documentation. It highlights the power of interactive tutorials and the importance of user testing in software development. The Talk also introduces learn.svelte.dev, a platform for learning full-stack tools, and discusses the roadmap for SvelteKit and its documentation.
SolidJS: Why All the Suspense?
JSNation 2023JSNation 2023
28 min
SolidJS: Why All the Suspense?
Top Content
Suspense is a mechanism for orchestrating asynchronous state changes in JavaScript frameworks. It ensures async consistency in UIs and helps avoid trust erosion and inconsistencies. Suspense boundaries are used to hoist data fetching and create consistency zones based on the user interface. They can handle loading states of multiple resources and control state loading in applications. Suspense can be used for transitions, providing a smoother user experience and allowing prioritization of important content.
From GraphQL Zero to GraphQL Hero with RedwoodJS
GraphQL Galaxy 2021GraphQL Galaxy 2021
32 min
From GraphQL Zero to GraphQL Hero with RedwoodJS
Top Content
Tom Pressenwurter introduces Redwood.js, a full stack app framework for building GraphQL APIs easily and maintainably. He demonstrates a Redwood.js application with a React-based front end and a Node.js API. Redwood.js offers a simplified folder structure and schema for organizing the application. It provides easy data manipulation and CRUD operations through GraphQL functions. Redwood.js allows for easy implementation of new queries and directives, including authentication and limiting access to data. It is a stable and production-ready framework that integrates well with other front-end technologies.
Full Stack Components
Remix Conf Europe 2022Remix Conf Europe 2022
37 min
Full Stack Components
Top Content
RemixConf EU discussed full stack components and their benefits, such as marrying the backend and UI in the same file. The talk demonstrated the implementation of a combo box with search functionality using Remix and the Downshift library. It also highlighted the ease of creating resource routes in Remix and the importance of code organization and maintainability in full stack components. The speaker expressed gratitude towards the audience and discussed the future of Remix, including its acquisition by Shopify and the potential for collaboration with Hydrogen.

Workshops on related topic

Developing Dynamic Blogs with SvelteKit & Storyblok: A Hands-on Workshop
JSNation 2023JSNation 2023
174 min
Developing Dynamic Blogs with SvelteKit & Storyblok: A Hands-on Workshop
Top Content
Featured WorkshopFree
Alba Silvente Fuentes
Roberto Butti
2 authors
This SvelteKit workshop explores the integration of 3rd party services, such as Storyblok, in a SvelteKit project. Participants will learn how to create a SvelteKit project, leverage Svelte components, and connect to external APIs. The workshop covers important concepts including SSR, CSR, static site generation, and deploying the application using adapters. By the end of the workshop, attendees will have a solid understanding of building SvelteKit applications with API integrations and be prepared for deployment.
Building WebApps That Light Up the Internet with QwikCity
JSNation 2023JSNation 2023
170 min
Building WebApps That Light Up the Internet with QwikCity
Featured WorkshopFree
Miško Hevery
Miško Hevery
Building instant-on web applications at scale have been elusive. Real-world sites need tracking, analytics, and complex user interfaces and interactions. We always start with the best intentions but end up with a less-than-ideal site.
QwikCity is a new meta-framework that allows you to build large-scale applications with constant startup-up performance. We will look at how to build a QwikCity application and what makes it unique. The workshop will show you how to set up a QwikCitp project. How routing works with layout. The demo application will fetch data and present it to the user in an editable form. And finally, how one can use authentication. All of the basic parts for any large-scale applications.
Along the way, we will also look at what makes Qwik unique, and how resumability enables constant startup performance no matter the application complexity.
Back to the Roots With Remix
React Summit 2023React Summit 2023
106 min
Back to the Roots With Remix
Featured Workshop
Alex Korzhikov
Pavlik Kiselev
2 authors
The modern web would be different without rich client-side applications supported by powerful frameworks: React, Angular, Vue, Lit, and many others. These frameworks rely on client-side JavaScript, which is their core. However, there are other approaches to rendering. One of them (quite old, by the way) is server-side rendering entirely without JavaScript. Let's find out if this is a good idea and how Remix can help us with it?
Prerequisites- Good understanding of JavaScript or TypeScript- It would help to have experience with React, Redux, Node.js and writing FrontEnd and BackEnd applications- Preinstall Node.js, npm- We prefer to use VSCode, but also cloud IDEs such as codesandbox (other IDEs are also ok)
Crash course into Astro and Storyblok
React Day Berlin 2023React Day Berlin 2023
119 min
Crash course into Astro and Storyblok
WorkshopFree
Arisa Fukuzaki
Arisa Fukuzaki
Headless architecture has gained immense popularity in recent years for its ability to decouple the frontend and backend, empowering developers to create engaging, interactive, and scalable web applications. 
In this workshop, we will quickly take a dive into the Headless World and Architecture. 
Additionally, we will build a blog website super quickly using Storyblok, a headless CMS that offers a real-time preview feature with nestable component approach, and Astro (3.0) which is already creating a buzz with the new app directory. 
- Master headless CMS fundamentals- Master an Astro & headless CMS approach- Use Atomic design in your Astro & Storyblok application- Creating pages, adding content and understanding how the dynamic routing works with headless
Full Stack GraphQL In The Cloud With Neo4j Aura, Next.js, & Vercel
GraphQL Galaxy 2021GraphQL Galaxy 2021
161 min
Full Stack GraphQL In The Cloud With Neo4j Aura, Next.js, & Vercel
WorkshopFree
William Lyon
William Lyon
In this workshop we will build and deploy a full stack GraphQL application using Next.js, Neo4j, and Vercel. Using a knowledge graph of news articles we will first build a GraphQL API using Next.js API routes and the Neo4j GraphQL Library. Next, we focus on the front-end, exploring how to use GraphQL for data fetching with a Next.js application. Lastly, we explore how to add personalization and content recommendation in our GraphQL API to serve relevant articles to our users, then deploy our application to the cloud using Vercel and Neo4j Aura.

Table of contents:
- Next.js overview and getting started with Next.js
- API Routes with Next.js & building a GraphQL API
- Using the Neo4j GraphQL Library
- Working with Apollo Client and GraphQL data fetching in Next.js
- Deploying with Vercel and Neo4j Aura
The Journey From React Frontend Development to Fullstack Development With Next.js
React Advanced 2024React Advanced 2024
143 min
The Journey From React Frontend Development to Fullstack Development With Next.js
Workshop
Eric Burel
Eric Burel
Join us as we journey from React frontend development to fullstack development with Next.js. During this workshop, we'll follow along the official Next.js Learn tutorial with Eric Burel, professional trainer and author of NextPatterns.dev. Together, we'll set up a Next.js website and explore its server-side features to build performant apps.
- Introduction: discovering Next.js and its server-centric philosophy- Crafting a perfectly optimized multi-page website- Making sense of Next.js server-side rendering capabilities- Conclusion: how Next.js empowers you as a React developer