La importancia de AMP
¿Qué es AMP?
Accelerated Mobile Pages
Páginas Móviles Aceleradas
En pocas palabras, significa sitios web más rápidos.
Menos consumo de batería
Menos consumo de batería
Menos consumo de datos
Menos consumo de batería
Menos consumo de datos
Monetización
Menos consumo de batería
Menos consumo de datos
Monetización
Usuarios felices
Desarrolladores
Editores
Plataformas
Búsqueda en Google
Sitio Original
Sitio AMP
AMP HTML
El HTML de toda la vida pero con algunas restricciones y añadiendo algunas vitaminas
No cambia la sintaxis, sino que añade nuevas funciones al formato que ya conocemos.
AMP JS
Una biblioteca JS para la garantizar la rapidez del sitio web
Convierte en asíncrono todo lo que viene de forma externa
AMP Cache
Una forma en que se guardan las páginas AMP, se almacenan en caché y se mejora el rendimiento
Todos los archivos JS e imágenes se cargan inmediatamente desde un mismo origen con HTTP 2.0
AMP ⚡️
Código de toda la vida
Velocidad
UX / UI
Publicidad
Código
AMP + Wordpress
Empezando con AMP
<!doctype html>
<html amp lang="es">
<head>
<meta charset="utf-8">
<script async src="https://cdn.ampproject.org/v0.js"></script>
<title>Hola, AMP</title>
<link rel="canonical" href="http://example.ampproject.org/article-metadata.html" />
<meta name="viewport" content="width=device-width,minimum-scale=1,initial-scale=1">
</script>
<style amp-boilerplate>body{-webkit-animation:-amp-start 8s steps(1,end) 0s 1 normal both;-moz-animation:-amp-start 8s steps(1,end) 0s 1 normal both;-ms-animation:-amp-start 8s steps(1,end) 0s 1 normal both;animation:-amp-start 8s steps(1,end) 0s 1 normal both}@-webkit-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@-moz-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@-ms-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@-o-keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}@keyframes -amp-start{from{visibility:hidden}to{visibility:visible}}</style><noscript><style amp-boilerplate>body{-webkit-animation:none;-moz-animation:none;-ms-animation:none;animation:none}</style></noscript>
</head>
<body>
<h1>Bienvenido a la web móvil</h1>
</body>
</html>
<!-- <html amp > -->
<html ⚡️ lang="es">
<html lang="es>
Etiqueta <html>
<script async src="https://cdn.ampproject.org/v0.js"></script>
Incluyendo AMP
Estilos
<style amp-boilerplate> ... </style>
Estilos por default
<style amp-custom>
/* Tus estilos */
body {
background-color: red;
}
h1 {
font-size: 20px;
}
</style>
Estilos personalizados
Estilos prohibidos
Estilos en las etiquetas
<h1 style="color: red;">Título</h1>
Todos los estilos deben definirse en la etiqueta <style amp-custom>
No podemos poner estilos en las etiquetas que definamos en nuestro HTML
Uso de !important
body {
background-color: red !important;
}
El uso de !important en nuestros estilos podría afectar a los estilos que tiene por default AMP
Archivos CSS externos
<link rel=”stylesheet”>
Importar archivos CSS a nuestro sitio web esta prohibido a excepción de las fuentes personalizadas.
Selector universal
* {
color: red;
}
Tiene problemas de rendimiento y podría afectar a otros selectores con sus estilos
Selector :not( )
:not(p) {
color: blue;
}
Al igual que con el selector universal, podría afectar a otros selectores con sus estilos
Pseudo: selectores / clases / elementos
a:hover {
color: orange;
}
Solo están permitidos en elementos que no comiencen con amp (Ej. amp-image)
Clases con la palabra amp
.amp-mi-clase {
font-weight: 700;
}
Dicha palabra esta reservada para el uso de AMP (Ej. -amp- & i-amp). Esto se hace para que no haya conflictos entre tu sitio web y AMP
Filtros
.filtro {
filter: grayscale(20%);
}
Están en la lista negra de AMP por problemas de rendimiento
Multimedia
Imagenes
<img src='img.jpg' height='500' width='500'></img>
<amp-img src='img.jpg' height='500' width='500'></amp-img>
HTML
AMP
<amp-img src="img.jpg" width="527" height="193" layout="responsive">
</amp-img>
AMP (Responsive)
Gifs
<amp-anim width='400' height='300' src='imagen.gif'></amp-anim>
AMP
<script async custom-element='amp-anim'
src='cdn'></script>
Nota: Necesitamos de un script más en el proyecto para poder usar dicho recurso.
Video
<amp-video width='720' height='480' src='video.mp4'
poster='imagen.jpg'></amp-video>
AMP
<video width='720' height='480' src='video.mp4'></video>
HTML
Audio
<amp-audio width='500' height='500' src='audio.mp3'>
<source type='audio/mpeg' src='audio.mp3'>
<source type='audio/ogg' src='audio.ogg'>
</amp-audio>
AMP
<script async custom-element='amp-audio'
src='cdn'></script>
Nota: Necesitamos de un script más en el proyecto para poder usar dicho recurso.
Atributos
Placeholders & Fallbacks
Los atributos placeholder y fallback nos van a ayudar a que el usuario siempre tenga algo que ver, ya sea problemas de conexión o de compatibilidad
Placeholder
Placeholder actúa como un preview de su elemento padre. Este tiene que ser siempre el hijo de alguien
<amp-anim>
<amp-img placeholder>
Placeholder
Placeholder se muestra por defecto, una vez que carga su elemento padre, este desaparece
<amp-anim src='gif.gif' width='466' height='355'>
<amp-img placeholder src='preview.png'></amp-img>
</amp-anim>
Fallback
Fallback se utiliza para indicarle al usuario cuando su navegador no soporta alguna característica en particular
<amp-video>
<div fallback></div>
Fallback
<amp-video width='720' height='480' src='video.mp4'>
<div fallback>
<p>Tu navegador no soporta el elemento video de HTML5.</p>
</div>
</amp-video>
Componentes / Tags
Incorporados
Extendidos
Experimentales
Componentes que están por defecto como amp-img o amp-video
Componentes de la biblioteca pero que deben ser añadidos de manera explicita, como amp-anim o amp-audio
Componentes que son liberados, pero que aún no están listos para su uso
amp-accordion
Un acordeón proporciona una manera para que los usuarios tengan un contenido diferente y dinámico
amp-lightbox
Permite una especie de popup para que el usuario interactúe
amp-facebook
Permite incrustar post o videos de Facebook en nuestro sitio AMP
amp-twitter
Permite incrustar Tweets en nuestro sitio AMP
amp-instagram
Permite incrustar fotos o videos de instagram en nuestro sitio AMP
amp-youtube
Permite incrustar videos de Youtube en nuestro sitio AMP
AMP
Una serie de bloques que al juntarse son capaces de formar grandes estructuras
Vinculación de páginas
Página no AMP
<link rel="amphtml" href="https://www.pagina.com/amp.html">
Página AMP
<link rel="canonical" href="https://www.pagina.com/documento-completo.html">
Solo una página (AMP)
<link rel="amphtml" href="https://www.pagina.com/amp.html">
Hacer Pruebas
https://validator.ampproject.org/
AMP Plugins
AMP
Este plugin dolo añade páginas AMP a las entradas de un blog y no te permite personalizar mucho
AMP FOR WP
Te permite más configuraciones funcionando previamente con el plugin anterior
AMP FOR WP
Puedes hacer cambios tanto de estructura como de diseño
¡Gracias!
Mi sitio web tarda mucho en cargar
¿Yo te dije que no usaras AMP ?
filisantillan.com/agenda
La importancia de AMP
By Fili Santillán
La importancia de AMP
- 2,479