SERGIOIGLESIAS

Blog sobre Joomla

Cómo crear, agregar y modificar meta-etiquetas personalizadas en Joomla!

@sergiois Tips Joomla 2 - 3 minutos Visto: 23282

En este artículo vamos a ver como agregar meta-etiquetas (meta-tags) desde cualquier fichero php de un componente Joomla!. Veremos el caso concreto de las etiquetas propias de facebook y cómo modificar las estándar de meta-description y meta-keywords.

Vamos a ver las meta-tags en Joomla!

API de Joomla!

En la biblioteca JFactory tenemos las funciones relacionadas con los "documentos" a través de getDocument(). Por lo tanto, lo primero que haremos será crear una variable para que podamos acceder a dichas funciones.

$doc = JFactory::getDocument();

La función que nos interesa para este caso addCustomTag.

Etiquetas de Facebook en Joomla!

Cuando compartimos algo en esta red social podemos seleccionar qué mostrar a partir de las etiquetas propias de Facebook. Estas etiquetas son las siguientes:

<meta property="og:title" content="Título del artículo"/>
<meta property="og:type" content="tipo"/>
<meta property="og:url" content="http://www.dominio.com/url-del-articulo"/>
<meta property="og:image" content="http://www.dominio.com/directorio/imagen-del-articulo.jpg"/>
<meta property="og:description" content="Texto introductorio del artículo que vamos a compartir"/>

Para generar estas etiquetas tendremos que añadir en nuestro código lo siguiente:

$doc = JFactory::getDocument();
$doc->addCustomTag( '' );
$doc->addCustomTag( '' );
$doc->addCustomTag( '' );
$doc->addCustomTag( '' );
$doc->addCustomTag( '' );

Con este código Joomla! añade las meta-etiquetas de Facebook entre de las etiquetasdel HTML que genera el artículo.

Etiquetas estándar en Joomla!

Muy parecido a lo que acabamos de ver para Facebook tendremos que hacer para modificar las etiquetas description y keywords. En este caso tendremos que hacer otra llamada a JFactory.

$app = JFactory::getApplication();
$app->addMetaTag('description', 'Descripción del artículo que se va a mostrar');
$app->addMetaTag('keywords', 'palabra clave1, palabra clave2, palabra clave3');

Esto generará entre las etiquetaslas siguientes meta-etiquetas:

<meta name="description" content="Descripción del artículo que se va a mostrar" />
<meta name="keywords" content="palabra clave1, palabra clave2, palabra clave3" />

[actualización - 16/12/2014] A petición de Manuel (BoleMC)

Cómo hacerlo de forma dinámica para que cada artículo tenga su propia personalización

Para realizar esta acción tendremos que hacer un override del componente com_content de la vista de artículos (article).

Para saber cómo crear un override os recomiendo hacer el curso sobre desarrollo de plantillas que os he preparado.

Una vez en el override, tendremos que añadir las siguientes líneas de código al inicio del fichero php (templates/tuplantilla/html/com_content/article/default.php):

$doc = JFactory::getDocument();
// extraemos las imagenes de intro y full text
$images  = json_decode($this->item->images);
$doc->addCustomTag( '' );
$doc->addCustomTag( '' );
$doc->addCustomTag( '' );
$doc->addCustomTag( '' );
// Si queremos coger la imagen de intro tendríamos que cambiar $images->image_fulltext por $images->image_intro
$doc->addCustomTag( '' );

[actualización - 11/07/2015] Tras un artículo de Guillermo Bravo

Vamos a poner las etiquetas de Twitter Card

$doc = JFactory::getDocument();
// extraemos las imagenes de intro y full text
$images  = json_decode($this->item->images);
$doc->addCustomTag( '' );
$doc->addCustomTag( '' );
$doc->addCustomTag( '' );
$doc->addCustomTag( '' );
$doc->addCustomTag( '' );
$doc->addCustomTag( '' );
// Si queremos coger la imagen de intro tendríamos que cambiar $images->image_fulltext por $images->image_intro
$doc->addCustomTag( '' );

Espero que os haya resultado sencillo este tip para Joomla!. Cualquier comentario ya sabéis que es bienvenido.

¿Te ha gustado el artículo?

Suscríbete a mi newsletter y recibe contenido exclusivo.
Podrás hacer gratis un Curso de desarrollo de plantillas Joomla.

32 comentarios

  • Hola Christian,<br /><br />Gracias por comentar en este blog ;-)<br /><br />He entrado en tu sitio web y he probado a compartir varias noticias y lo hace de forma correcta. Lo he probado de varias maneras y, en todas, el resultado es el mismo.<br />He visto que tienes varios servicios de compartir: sharethis y algún plugin (o los propios que trae el template). Pero, a priori, parece que va bien como te comento.<br /><br />Lo que sí he visto es que en alguna noticia, en el código, se generan 2 etiquetas y la última que hay no es correcta. Pero aún así, se comparte bien.<br /><br />De todas formas hay que estar siempre pendiente de los cambios que se producen en esta red social.<br /><br />Si has hecho algún cambio y se ha solucionado, perfecto!!<br /><br />Gracias de nuevo por comentar.<br /><br />Un saludo,
  • Buenas tardes, Sergio, te escribo desde Ecuador.<br />El caso es que cuando comparto en facebook de forma automática, no consigo que salga la imagen que corresponde al articulo, mi plantilla es teline v y en un principio iba bien, puse las meta etiquetas de tu página pero sigo sin tener los resultados, agradecería un poco de ayuda.<br />Muchas gracias Sergio. y felicidades por tu página.
  • Bueno, les comento... no sé por qué razón en el Open Graph Object Debugger https://developers.facebook.com/tools/debug/ (erramienta para eliminar el caché de facebook ) al escanear el enlace me toma la imagen correcta, pero si yo reviso la información de Graph API evidentemente toma primero los dos logos de la página y cualquier otra imagen menos la del articulo, al revisar intenté varias opciones tratando de modificar los logos, pero finalmente los dejé como estaba y me dí cuenta que insertando la misma imagen (de opciones de imagenes y enlaces) dentro del artículo y colocandole descripción y título lo deja como primera opción de publicación, no entiendo esto porqué y pues es depronto algo lógico pero Joomla en (Opciones de imagenes y enlaces) no se puede cargar la imagen con el título.<br />Es una solución algo diferente pero me funciona por fin. Si alguien puede darle una explicación lógica y una solución más profesional por favor no dude en comunicarmelo.. Gracias
  • Hola buenas noches,<br />Tengo Joomla 3.4 con una plantilla que no tiene por defecto compartir todo lo que cargo como articulos que se visualizan como blog, entonces descargué un plugin de Addthis para insertar los botones de diferentes redes sociales despues de cada articulo, todo perfecto, pero al compartir en facebook no salían las imagenes que cargaba para los artículos, entonces navegando me encontré que necesitaba unos META open graph para poder lograr esto, entonces me encontré con un plugin llamado "simple facebook meta", me mostraba la imagen, titulo y contenido text en un popup despues de dar click en el boton de compartir en facebook(Addthis) pero al hacerle click en compartir(en el popup) y revisarlo en el perfil de facebook me daba cuenta que cambiaba la imagen automáticamente por la del logo de la página y el texto perfecto. no sé porque sucede esto esta la url: http://kaprichosas.com/blog-kaprichosas Ayuda por favor.
  • Gracias por la rápida respuesta, mi plantilla es JM Joomclassifieds y este es mi sitio web : www.buychollos.com
  • Hola Marcos,<br /><br />Lo primero, gracias por escribir. En cuanto a tu consulta, esto depende de la plantilla que utilices en tu sitio web. Puede que la plantilla tenga overrides o no del com_content. Si puedes poner la URL para ver de qué plantilla se trata o si quieres puedes ponerte en contacto conmigo a través del formulario de contacto.<br /><br />Un saludo,
  • Hola Sergio, me estoy volviendo loco para que facebook comparta bien las imágenes de cada articulo que subo a mi web, conseguí hacerlo con una imagen y descripción estáticas pero lo que quiero es lo que dices de las imágenes y descripciones dinámicas para cada articulo, pero no se llegar al archivo php que propones (templates/tuplantilla/html/com_content/article/default.php), entiendo que se llega a el por ftp pero es que sigo esa ruta y a mi no me aparece así. Agradezco cualquier ayuda, gracias.
  • Hola Manuel!! Bienvenido al blog y gracias por comentar.<br /><br />Acabo de actualizar el artículo con lo que comentas. Espero que tanto a ti como a otros usuarios os venga bien.<br /><br />Un saludo!!
  • Gracias por el tip Sergio.<br />Pero lo que compartes es con unos metas específicos ¿como sería para que los coja de manera dinámica? ya que como es lógico cada página debe tener sus propios metas de open graph por ejemplo. Gracias de nuevo por compartir tus conocimientos :)

Artículos relacionados

Solicita presupuesto

¿Quieres una página web que funcione?

Contacta conmigo y hablemos de tu proyecto.