Primeros pasos con Astro JS: Guía de instalación y funciones básicas

18 de julio de 2023

Primeros pasos con Astro JS Guía de instalación y funciones básicas

La investigación corre a cargo de Chris

Al principio, todo lo que teníamos eran sitios web HTML estáticos. Pero ahora, entra Astro-un nuevo framework de aplicaciones multipágina JS que ha estado ganando increíble tracción dentro de la comunidad de desarrollo web en los últimos meses.

El framework Astro hace uso principalmente de tecnologías como Angular, React y Node.js para crear experiencias web únicas para los usuarios. Empezar a utilizar Astro es muy sencillo: basta con tener conocimientos básicos de HTML, CSS y JavaScript (o uno de los marcos de trabajo mencionados).

Así que, si quieres empezar a utilizar este nuevo framework, esta entrada del blog te proporcionará una visión general del proceso de instalación y algunas de las características principales.

¡Comencemos!

¿Qué es Astro JS?

Astro, el creador de sitios web definitivo, está diseñado específicamente para crear sitios web cautivadores y ricos en contenido. Astro tiene todo lo que necesitas para crear sitios de marketing, aplicaciones de una sola página, sitios de documentación, blogs, carteras o incluso sitios de comercio electrónico.

Por otro lado, la mayoría de los frameworks web modernos se centran en la creación de aplicaciones web. Estos diferentes frameworks son perfectos para crear esas sofisticadas experiencias similares a las de una aplicación directamente en tu navegador.

Ahora, Astro adopta un enfoque diferente. Astro trabaja para ofrecerte experiencias de contenido alucinantes. Por eso Astro crea ciertas compensaciones y ofrece características de rendimiento inmejorables que otros frameworks web centrados en aplicaciones no pueden igualar.

¿Por qué utilizar Astro?

Como framework Javascript, Astro ofrece una serie de ventajas sobre otras tecnologías de desarrollo web. Por eso se ha hecho popular para crear sitios web.

Si está pensando en crear un sitio web con experiencias de usuario enriquecidas, merece la pena tener en cuenta Astro. Estas son algunas de las ventajas que debería conocer:

Sitios web de carga rápida

Astro es un centro neurálgico, que ofrece contenido estático y renderizado en servidor hecho a medida para sitios web que dan prioridad al contenido y que son compatibles con SEO. Ya se trate de un blog cautivador, un curso inmersivo o un sitio de marketing atractivo, Astro tiene todo lo que necesitas.

Startechup Servicio de diseño UI UX

Interfaz de usuario agnóstica

A diferencia de Next.js, que se limita a React, o Nuxt.js, que requiere conocimientos de Vue, Astro te libera de cualquier restricción de marco de interfaz de usuario. Tienes la libertad de no usar ninguno, crear el tuyo propio o explorar la plétora de integraciones compatibles.

Temas prefabricados

Astro ofrece una increíble gama de temas y plantillas prediseñados para poner en marcha tu creatividad en un abrir y cerrar de ojos.

Fácil de entender

No hay necesidad de sumergirse en React o Vue para comenzar su viaje Astro. Con su motor de plantillas que se asemeja al HTML plano y la separación del código limpio de la presentación, puedes empezar con un proyecto vacío y construirlo a tu propio ritmo.

Pilas incluidas

Astro ofrece una serie de características que se alinean con nuestras expectativas para un framework JavaScript/TypeScript moderno. Entre ellas se incluyen las esperas de nivel superior, la compatibilidad con Markdown y MDX, y la inclusión de ESM.

Utiliza la arquitectura de islas

La arquitectura en isla le permite combinar a la perfección contenido estático, componentes renderizados en servidor y componentes renderizados en cliente en una sola página, fomentando sitios interactivos con facilidad. Es más, puedes incluso mezclar y combinar diversos frameworks en la misma página, lo que abre infinitas posibilidades para crear microportadas cautivadoras.

¿Cuándo no se debe utilizar Astro?

Incluso siendo uno de los frameworks de interfaz de usuario más populares, hay ciertos escenarios en los que el uso de Astro en sus proyectos puede no ser adecuado.

He aquí algunas situaciones a tener en cuenta:

Sitios web pequeños y estáticos

Si estás trabajando en un proyecto pequeño que consiste sólo en unas pocas páginas estáticas sin funcionalidad compleja o contenido dinámico, el uso de Astro puede introducir una sobrecarga innecesaria. En tales casos, un generador de sitios estáticos más simple o incluso HTML/CSS simple podría ser más apropiado.

Proyectos muy dependientes de la renderización del lado del servidor (SSR)

Astro se centra principalmente en la generación de sitios estáticos y el renderizado del lado del cliente (CSR). Astro puede no ser la mejor opción si su proyecto depende en gran medida de la renderización del lado del servidor, como para el contenido dinámico generado por el servidor o las operaciones específicas del servidor. Otros frameworks o librerías especializadas en SSR, como Next.js o Nuxt.js, podrían ser más adecuados.

Estrecha integración con marcos backend

Si tu proyecto implica una estrecha integración con un framework backend o se basa en tecnologías del lado del servidor como Node.js, Express.js o Django, el enfoque de generación de sitios estáticos de Astro podría no alinearse bien con los requisitos del backend. En estos casos, los frameworks que ofrecen una fuerte integración con el backend, como Next.js, pueden ser una mejor opción.

Aplicaciones de rendimiento crítico

Aunque Astro se esfuerza por ofrecer un renderizado eficiente y un rendimiento óptimo, ciertas aplicaciones críticas para el rendimiento con requisitos específicos pueden necesitar un control de menor nivel sobre las optimizaciones. Si tiene una aplicación con criterios de rendimiento estrictos o necesidades de renderizado únicas, las abstracciones de Astro pueden limitar su capacidad para afinar las optimizaciones de rendimiento.

Proyectos con amplias integraciones de terceros

Si tu proyecto depende en gran medida de librerías, frameworks o plugins de terceros que no son compatibles con Astro o carecen de soporte para el sistema de compilación de Astro, puede causar conflictos o problemas de compatibilidad. Asegúrate de que el ecosistema que rodea tu proyecto es compatible con Astro antes de comprometerte con él.

¿Cómo instalar Astro JS?

La forma más fácil de familiarizarse con Astro es empezar a utilizarlo. Si no sabes cómo empezar, aquí tienes una guía rápida sobre cómo instalar y empezar a utilizar Astro.

Si cumples estos requisitos, podrás empezar a utilizar Astro en un abrir y cerrar de ojos:

  • Node.js - v16.12.0 o superior. (a partir de Astro v2.4.5)
  • Editor de texto - Recomendamos VS Code con nuestro Ampliación oficial de Astro.
  • Terminal - Se accede a Astro a través de su interfaz de línea de comandos (CLI).

1. Ejecute el asistente de configuración

npm create astro latest

Después de entrar, el comando Astro create te guiará a través de la configuración inicial:

2. Le pedirá la ubicación y el nombre de su proyecto. Por defecto da un nombre de proyecto aleatorio.

comando astro create

3. A continuación, le preguntará si desea utilizar una plantilla, archivos de ejemplo o un proyecto vacío.

nuevo nombre de proyecto en Astro

4. A continuación, le preguntará si desea instalar las dependencias.

plantilla astro

5. Luego, le preguntará si planea escribir Typescript. En caso afirmativo, le preguntará qué tan estricto.

escribir TypeScript

6. Por último, le preguntará si desea inicializar un nuevo repositorio git.

inicializar un nuevo repositorio git
respuesta del repositorio git

7. Ahora puede ejecutar el proyecto en su local utilizando:

npm run dev

Características de Astro Pages

Astro no es un framework JS para sitios web al uso. Es una potente herramienta que prioriza el contenido y adopta un enfoque agnóstico de la interfaz de usuario.

Veamos algunas de las características clave que hacen que Astro destaque sobre la competencia:

Plantillas

Proporciona plantillas para aquellos que quieren empezar a codificar de inmediato y saltarse el proceso de configuración. Tiene algunas opciones como un sitio de Blog, plantilla de Documentación, Portafolio, o una plantilla vacía. 

Plantillas Astro

Temas

Al igual que WordPress u otros CMS, Astro cuenta con un puñado de temas que puedes utilizar gratuitamente. Aportados por su creciente comunidad, nunca pasarán de moda.

temas astro

Integraciones

Astro Integrations le permite elevar la funcionalidad y el comportamiento de su proyecto sin esfuerzo. Con la máxima facilidad, puedes crear una integración a medida, aprovechar las integraciones oficiales o aprovechar el poder creativo de las integraciones creadas por la comunidad.

integraciones astro

Aquí tienes las integraciones oficiales que puedes utilizar:

Estructura

Al igual que otros Frameworks Javascript, cada raíz de proyecto Astro debe incluir los siguientes directorios y archivos:

  • src/* - El código fuente de su proyecto (componentes, páginas, estilos, etc.)
  • public/* - Sus activos no codificados ni procesados (fuentes, iconos, etc.)
  • paquete.json - Un manifiesto de proyecto.
  • astro.config.mjs - Un archivo de configuración de Astro. (recomendado)
  • tsconfig.json - Un archivo de configuración TypeScript. (recomendado)

Componentes Astro

Un componente Astro utiliza la extensión de archivo: .astro

Son componentes de plantillas HTML sin tiempo de ejecución del lado del cliente. Al igual que otros frameworks, los componentes Astro son reutilizables.

Un componente Astro se compone de dos partes principales: el Script del Componente y la Plantilla del Componente.

Componente Script

  • Puedes usar el componente script para escribir cualquier código javascript que necesites para renderizar tu plantilla. Astro utiliza tres guiones (-) entre el código javascript para diferenciarlo del contenido. Esto se escribe en la parte superior del archivo.

Plantilla de componentes

  • La plantilla del componente está debajo del Script del componente y determina la salida HTML de su componente. Puede utilizar etiquetas HTML, componentes importados, directivas Astro y expresiones Javascript.

Los componentes reutilizables se denominan "layouts". Convencionalmente usamos el término "diseño" para los componentes Astro que proporcionan elementos comunes de interfaz de usuario compartidos a través de las páginas, tales como cabeceras, barras de navegación y pies de página. Los componentes de diseño se colocan normalmente en un directorio src/layouts en el proyecto para su organización, pero esto no es un requisito.

Atrezzo

Un componente Astro puede definir y aceptar accesorios. Estos props se vuelven disponibles para la plantilla del componente para renderizar HTML. Los props se pueden recuperar usando Astro.props.

Tragamonedas

El elemento es un marcador de posición para contenido HTML externo, que le permite inyectar elementos hijos de otros archivos en la plantilla de su componente.

Páginas

Las páginas son archivos que viven en el subdirectorio src/pages/ de tu proyecto Astro. Son responsables de gestionar el enrutamiento, la carga de datos y el diseño general de cada página de tu sitio web.

Tipos de archivo compatibles: .astro, .md / .mdx, .html, .js / .ts

Astro utiliza una estrategia de enrutamiento denominada enrutamiento basado en archivos. Cada archivo en su directorio src/pages/ se convierte en un punto final en su sitio basado en su ruta de archivo. Por ejemplo, si tiene una página Acerca de, about.astro, puede acceder a ella automáticamente utilizando www.example.com/about.

Más información Rutas en Astro.

Cómo migrar sus proyectos a Astro

Astro tiene un puñado de guías para migrar tu proyecto existente desde otra plataforma o framework a Astro.

Estos son los frameworks y plataformas con guías disponibles: 

astroguías

Habrá más disponibles a medida que contribuya la creciente comunidad Astro.

Consulte las guías de migración ¡Aquí!

Si optas por cambiar a Astro, tendrás que hacer algunos ajustes, y los temas anteriores que tenías de la otra plataforma no se llevarán a Astro. En su lugar, tendrás que crear un nuevo proyecto Astro y seleccionar entre las plantillas o temas disponibles proporcionados por la comunidad y Astro.

Puede utilizar estos comandos para utilizar las plantillas o los temas:

comandos astro

Aunque pasarse a Astro supondrá un gran cambio, le reportará muchos beneficios a largo plazo, especialmente en SEO, velocidad del sitio y resultados de la página de Google.

¿Necesita un equipo Astro para su proyecto?

Astro cuenta con una creciente comunidad de desarrolladores, ingenieros y profesionales del diseño que pueden ayudarte a crear el sitio web perfecto. Con su ayuda, puedes construir algo que se adapte a tus necesidades específicas.

StarTechUP es una red de profesionales experimentados especializados en proyectos Astro. Desde el diseño personalizado hasta la construcción completa de sitios web, nuestro equipo le ayudará a crear algo que se ve muy bien y funciona a las mil maravillas.

También ofrecemos una gama completa de servicios para software a medida, backend y ingeniería frontend, y DevOps. Así que, sean cuales sean las necesidades de su proyecto, nuestro equipo está aquí para ayudarle a que sea un éxito.

Póngase en contacto con nosotros para obtener más información sobre cómo podemos ayudarle a crear algo increíble con Astro.

Sobre el autor: Andrea Jacinto - Redactor de contenidos

Escritora de contenidos con una sólida formación en SEO, Andrea ha estado trabajando con vendedores digitales de diferentes campos para crear artículos optimizados que sean informativos, digeribles y divertidos de leer. Ahora, escribe para StarTechUP con el fin de ofrecer los últimos avances en tecnología a los lectores de todo el mundo. Ver en Linkedin

MÁS INFORMACIÓN