Mejora el SEO y comparte en redes sociales en Angular. Tutorial AngularJs. Parte 1
Índice de contenido
- Introducción 🌟
- Definición del problema 🤔
- Solución propuesta 💡
- Implementación con ExpressJS ✨
- Configuración del servidor 🛠️
- Identificar los crawlers 🕵️♂️
- Renderizado del contenido HTML 🖌️
- Redirección de los crawlers 🚀
- Generación de vistas con Jade 🌿
- Pruebas usando Facebook Debugger 🎯
- Conclusiones y próximos pasos 🏁
🌟 Introducción
En este tutorial, vamos a abordar el problema de cómo hacer que las aplicaciones de AngularJS sean amigables para los rastreadores de motores de búsqueda como Facebook y Google. Muchas veces, estas aplicaciones no son indexadas correctamente, lo que puede afectar el alcance y la visibilidad de nuestro contenido. Sin embargo, existe una solución utilizando ExpressJS y renderizado del lado del servidor. En este artículo, explicaremos paso a paso cómo implementar esta solución y garantizar que nuestras aplicaciones AngularJS sean indexadas correctamente.
🤔 Definición del problema
Cuando creamos aplicaciones de AngularJS, utilizamos el enfoque de renderizado del lado del cliente, lo que significa que el contenido HTML se genera en el navegador del usuario mediante JavaScript. Sin embargo, esto presenta un problema para los rastreadores de motores de búsqueda, ya que no pueden interpretar el JavaScript y, por lo tanto, no pueden acceder a todo el contenido de nuestras aplicaciones. Esto resulta en una indexación deficiente por parte de los motores de búsqueda y una falta de visibilidad en los resultados de búsqueda.
💡 Solución propuesta
La solución propuesta para este problema es utilizar el renderizado del lado del servidor para generar vistas HTML estáticas de nuestras aplicaciones AngularJS. De esta manera, los motores de búsqueda pueden acceder fácilmente al contenido y indexarlo correctamente. Para lograr esto, utilizaremos ExpressJS, un marco de aplicaciones web para Node.js, que nos permite crear un servidor y manejar solicitudes HTTP.
✨ Implementación con ExpressJS
🛠️ Configuración del servidor
Para comenzar, necesitaremos configurar nuestro servidor ExpressJS. Primero, debemos instalar las dependencias necesarias ejecutando el comando npm install
. Luego, en nuestro archivo server.js
, requeriremos los módulos necesarios y crearemos una instancia de Express.
const express = require('express');
const app = express();
const port = 5000;
🕵️♂️ Identificar los crawlers
El siguiente paso es identificar si el usuario que accede a nuestro sitio web es un rastreador o un usuario real. Para hacer esto, utilizaremos una función middleware proporcionada por ExpressJS. Dependiendo del agente del usuario, podemos determinar si es un rastreador de Facebook u otro motor de búsqueda.
app.use((req, res, next) => {
const userAgent = req.headers['user-agent'];
if (userAgent.includes('Facebook')) {
// Renderizar vista HTML para el crawler de Facebook
} else {
// Redirigir al usuario a la página index.html
}
next();
});
🖌️ Renderizado del contenido HTML
Cuando se detecta un rastreador de Facebook, generamos una respuesta con la vista HTML correspondiente. Para esto, utilizaremos un motor de plantillas como Jade (ahora llamado Pug).
app.set('views', './views');
app.set('view engine', 'pug');
app.get('/', (req, res) => {
res.render('home', { title: 'Mi aplicación AngularJS' });
});
🚀 Redirección de los crawlers
En el caso de que el usuario no sea un rastreador de Facebook, lo redirigimos a la página principal de nuestra aplicación AngularJS. Esto es importante para garantizar que los usuarios reales vean la versión completa de la aplicación y no solo el contenido estático.
app.get('/', (req, res) => {
res.sendFile(__dirname + '/public/index.html');
});
🌿 Generación de vistas con Jade
Para generar las vistas HTML, utilizaremos Jade (Pug), un motor de plantillas muy popular en la comunidad de Node.js. En nuestras vistas, podemos utilizar la sintaxis Pug para representar dinámicamente el contenido de nuestra aplicación.
doctype html
html
head
title= title
body
h1 ¡Bienvenido a mi aplicación AngularJS!
// Resto del contenido de la aplicación
🎯 Pruebas usando Facebook Debugger
Para asegurarnos de que nuestra solución está funcionando correctamente, podemos utilizar la herramienta Facebook Debugger. Con esta herramienta, podemos verificar cómo se ve nuestra página para el rastreador de Facebook en tiempo real. También podemos ver qué contenido se está compartiendo en Facebook y solucionar cualquier problema que pueda surgir.
🏁 Conclusiones y próximos pasos
En este tutorial, hemos explicado cómo hacer que las aplicaciones de AngularJS sean amigables para los rastreadores de motores de búsqueda utilizando ExpressJS y renderizado del lado del servidor. Hemos visto cómo configurar un servidor, identificar crawlers de Facebook y generar vistas HTML estáticas. Asegurarnos de que nuestras aplicaciones AngularJS sean indexadas correctamente es crucial para aumentar la visibilidad y el alcance de nuestro contenido. Esperamos que este artículo haya sido útil y que puedas aplicar estos conceptos en tus propios proyectos.
FAQ
Q: ¿Es necesario utilizar ExpressJS para renderizar nuestras aplicaciones AngularJS?
A: Sí, ExpressJS es una herramienta muy útil para el renderizado del lado del servidor en aplicaciones de AngularJS. Proporciona una forma sencilla de generar vistas HTML estáticas y garantizar que nuestras aplicaciones sean indexadas correctamente por los motores de búsqueda.
Q: ¿Se pueden utilizar otros motores de plantillas en lugar de Jade (Pug)?
A: Sí, ExpressJS es compatible con varios motores de plantillas, como EJS y Handlebars. Puedes elegir el que mejor se adapte a tus necesidades y preferencias.
Q: ¿Qué ventajas tiene utilizar el renderizado del lado del servidor en aplicaciones de AngularJS?
A: El renderizado del lado del servidor permite que el contenido de nuestras aplicaciones sea indexado correctamente por los motores de búsqueda, lo que aumenta su visibilidad en los resultados de búsqueda. También mejora el rendimiento al generar vistas HTML estáticas, lo que reduce la carga en el navegador del usuario.
Q: ¿Es posible implementar esta solución en aplicaciones grandes y dinámicas?
A: Sí, esta solución es escalable y puede aplicarse a aplicaciones grandes y dinámicas. Sin embargo, requerirá un poco más de configuración y manejo de rutas para garantizar que todas las páginas sean renderizadas correctamente.
Q: ¿Dónde puedo encontrar más información sobre ExpressJS y renderizado del lado del servidor?
A: Puedes encontrar más información en la documentación oficial de ExpressJS (https://expressjs.com/) y en recursos en línea como blogs y tutoriales.
Q: ¿Existen otras herramientas o enfoques para mejorar la indexación de las aplicaciones AngularJS?
A: Sí, existen otras herramientas y enfoques que pueden ayudar a mejorar la indexación de las aplicaciones AngularJS, como prerender.io y Angular Universal. Estas herramientas utilizan técnicas avanzadas de renderizado del lado del servidor para garantizar una indexación óptima por parte de los motores de búsqueda.