Local blog for Spanish speaking developers in LATAM
AMP como marco de trabajo web
martes, 18 de junio de 2019
Actualización (2/5/2019)
: Se agregó un párrafo a fin de aclarar la compatibilidad con otros marcos de trabajo (para no sugerir un juego de suma cero) y se quitó texto sobre cómo se malinterpretó AMP, dado que no era necesario para transmitir la idea que queríamos dar.
¿Has leído últimamente alguna entrada de blog en la que se comparen los marcos de trabajo más populares? ¿Has participado en alguna encuesta sobre herramientas de frontend? Apostaría lo que sea a que AMP no estaba en la lista. Y eso me parece extraño, considerando los millones y millones de dominios que ejecutan este formato. ¿Cómo es posible?
Aquí encontrarás el contenido de esta entrada de blog en una superproducción de video. Deberías ver esto. Confía en mí. Valdrá la pena.
Cómo llegamos hasta aquí: marcos de trabajo de HTML contra JS, percepción como formato de distribución y AMP sincronizado
La primera razón por la que no se percibe a AMP como un marco de trabajo es porque AMP no es un marco de trabajo de
JavaScript
. Está
escrito
en JS, pero el lenguaje de autor que tú ves es HTML, por lo que técnicamente es un marco de trabajo HTML. La idea de los marcos de trabajo HTML no es nueva, pero siguen siendo bastante raros, por lo que a menudo no se consideran una alternativa seria.
La segunda razón es que muchos comparan a AMP con RSS, y los medios de comunicación lo posicionaron como competidor de otros formatos de contenido multimedia de jardín vallado desarrollados por otras grandes empresas. Esa narrativa no fue de ayuda y, por si sirve de algo, a nosotros, el equipo de AMP, nunca nos gustó esa comparación (aunque también contribuimos confundiendo a los lectores con palabras complicadas como
entorno de ejecución
y
formato HTML de AMP
). Las páginas web ya son un gran formato de distribución, y AMP lo mejora acelerando la entrega mediante cachés y agrupando el contenido principal, por ejemplo, mediante la integración de CSS.
La tercera razón es que la mayoría de los sitios AMP actuales utilizan
AMP sincronizado
, una técnica que habilitamos para
conectar una página web existente que no es de AMP con un equivalente que sí lo es
. AMP sincronizado puede ser útil porque la inversión inicial es mucho menor: si termino de empacar y luego me doy cuenta de que quiero llevar más cosas, puedo hacer otra maleta y viajar con dos, pero eso será una molestia. Lo mismo ocurre con AMP sincronizado. Es muy difícil mantener ambas versiones con el paso del tiempo, y AMP sincronizado no fue concebido para tener un estado final. (Por eso, ahora lo llamamos
Modo transicional
en
AMP para WordPress
).
De Accelerated Mobile Pages a AMP
Incluso nuestro nombre ha causado confusión. Desde hace tiempo, he tenido algunos problemas para explicar correctamente qué
es
AMP, especialmente a aquellos que están familiarizados con su nombre completo: Accelerated Mobile Pages. La realidad es que, desde hace mucho tiempo, AMP es más que lo que indica su nombre:
AMP no brinda solamente
aceleración
, ya que incluye beneficios de UX integrados, como inhabilitar anuncios intersticiales, forzar un subproceso principal independiente para interacciones fluidas, etc.
AMP no es solamente para
dispositivos móviles
, ya que funciona en varios tipos de dispositivos, como computadoras de escritorio y tablets, e incluye
funciones prácticas de diseño responsivo
.
Y AMP ya no es para
páginas
solamente: ahora puedes usarlo en
anuncios
,
correos electrónicos
y
artículos
.
Entonces, ¿cuál es la solución? Es fácil. Como
anunció Malte, líder tecnológico de AMP
, en AMP Conf,
AMP ahora solo es AMP, y ya no significa Accelerated Mobile Pages
(si quieres usar una versión expandida, ¿qué te parece
Awesome Magical Power?
).
De la página al sitio: cómo implementar AMP y utilizarlo como servicio
Los desarrolladores de AMP queremos que se convierta en una opción natural para el desarrollo web moderno de sitios de contenido y que tú puedas elegir AMP como marco de trabajo porque realmente te hace más productivo. Esa es nuestra misión principal de este año, y hemos puesto en marcha un nuevo sitio en
amp.dev
(junto con nuevos contenidos y
cursos para principiantes
) a fin de ayudarte a hacerlo. Entonces, ¿qué obtienes cuando adoptas AMP como marco de desarrollo (además de lo obvio, como velocidad, UX y componentes fáciles de usar)?
Para empezar, te enfocarás más en el diseño, el estilo y el contenido, y menos en el código estándar. El desarrollo web se ha vuelto demasiado difícil, y es más importante que nunca elegir el nivel adecuado de abstracción, con la cantidad justa de flexibilidad para tu caso de uso. Nos encargaremos de mantener JS para todos los componentes y enviaremos actualizaciones compatibles cada dos semanas. A esta forma de reducir la carga de mantenimiento la llamamos "
AMP como servicio
" (mira la
gran charla de Naina
sobre este tema).
Ahora solo mantendrás una versión de cada página haciendo que tu contenido de AMP sea
canónico
, lo que también se conoce como "
AMP primero
", y eso significa que tus páginas se beneficiarán del rendimiento de AMP y de las optimizaciones de UX en computadoras de escritorio, dispositivos móviles y mucho más.
Bento: cómo mezclar y hacer coincidir componentes de AMP en páginas que no son de AMP y brindar interoperabilidad con otros marcos de trabajo
Mira el anuncio de Bento en
What's next in AMP
de AMP Conf '19.
"AMP primero"
no significa que estrictamente todas las páginas de tu sitio deben estar en formato AMP. En ocasiones, es posible que quieras la máxima flexibilidad y que la distribución no sea una gran preocupación, por ejemplo, en un área exclusiva para miembros o un carrito de compras complejo. En ese caso, podrías utilizar JavaScript u otro marco de trabajo para potenciar esa parte de la experiencia.
Para poder reutilizar las plantillas existentes que compilaste con componentes de AMP, estamos trabajando en lo que llamamos
Bento AMP
, la capacidad de utilizar componentes de AMP de forma "no gestionada", sin cargar el archivo JS principal de AMP (v0.js) y coexistiendo con otros componentes y marcos de trabajo web en la misma página.
Esto, junto con marcos de trabajo como Next.js que agregan compatibilidad para AMP y
amp-script
en el lado del servidor, la capacidad de ejecutar JavaScript personalizado en un trabajador web, significa que AMP y otros marcos de trabajo pueden coexistir pacíficamente y pueden fortalecerse mutuamente, lo cual nos entusiasma mucho.
Desarrollo acelerado con compatibilidad para JS y ejecución de componentes de AMP fuera de ese formato
Por supuesto, es posible que no tenga sentido para ti dejar todo y volver a implementar tu sitio en formato AMP justo ahora, ¡y eso está bien! Solo quiero que sepas que hemos crecido bastante y que, cuando te propongas rediseñar o crear algo nuevo, AMP estará aquí para ayudarte a tener éxito.
Con las capacidades de vinculación de estado dinámico de
amp-bind
, la obtención de datos dinámicos de
amp-list
y la capacidad de utilizar JavaScript personalizado mediante
amp-script
, las posibilidades para los sitios de contenido ahora son infinitas. Por último, con el nuevo
régimen de proyectos abiertos
, el futuro de AMP está disponible para que le dé forma todo aquel que quiera que la Web siga floreciendo.
Publicado por Paul Bakaus, desarrollador de AMP
Labels
.app
.dev
.txt
#AMP
#CPU
#DeveloperStudentClubs
#DevFest
#DragonBall
#DSC
#Forsety
#ForsetySecurity
#freeandopen
#GCP
#Google
#GoogleCloud
#GoogleCloudPlatform
#GoogleLaunchpad
#iio2009
#Kubernetes
#MaterialDesign
#OneCommunity
#Security
#TensorFlow
#UPGlobal
#UpLatam
#WithGoogle
+page
10 YEARS
2013
2019
64 bits
A/B Testing
AA
Accelerator
Action on Goolge
actionbar
Actions
Actions Console
AdMob
Ads
adwords
adwords api
AI
AIY
ajax
alarmmanager
ALFA
almacenamiento
alojamiento de proyectos en google code
AMP
AMP Conf
AMP Project
amp-date-picker
amphtml
Analytics
Andorid
android
Android (operating System)
Android 3.1
android 3.3
android 4.2
android 9
Android 9 Pie
Android App Bundle
android design
Android Dev Summit
Android Developers
android Jetpack
Android P
Android SDK
Android Studio
Android Things
Android Wear
AndroidDevStory
androititlan
angelina jolie
Annotation
Announcements
anuncios
API
API Analytics YouTube
Apigee
APIs
Aplicaciones
aplicaciones chrome
app
app engine
App Indexing
app invites
App Server
applications
AppQuality
apps
Apps Script
AR
ARCore
arte
ATLAS
AWP
backend
Base64
batch
Bava
Betatesting
Better Ads Standars
bigdata
BigQuery
Biometrics
blink
bootcamp
BOT
BQ
Business
búsqueda ajax
by Google
byCases
byCommunity
byDevelopers
byGoogle
C++
CALENDAR
Cardboard
case
caso de éxito
Casos de éxito
casos destacados
CCOSS
Century Fox
chat
chrome
chrome web store
chromebook
chromecast
chromium
Cinéfilos
cloud
Cloud Anchors
CLOUD endpoints
Cloud Firestore
Cloud Functions
Cloud IoT Core
Cloud Next
Cloud Scheduler
Cloud services
cloud test lab
Cloud Text-to-Speech
Cloud Translation
CMD en vivo
coconut
code
code-in
code.org
CodeLabs
código
código abierto
Colab
colombia
Communities
Comunidades
concurso google
conference
contenedores
convocatoria
Coordinate
crashlytics
CRE
crear aplicaciones ajax
creatividad
Crowdsource
CSS
cws
daniela robles
dart
dart sdk
dartium
dartlang
Dataset
DCL
denis labelle
desarrolladores
Desarrolladores Google
desarrolladores LatAm
Desarrollar
Design
Design Sprint
Destacados
dev
Dev.f
DevArt
DevBus
DevBusLatAm
Developer Bus
Developer Summit
DeveloperConsole
developers
DevFest
devoxx
dialogflow
diseño UX
Distribuir
DNS
DOM
domain
DonkeyCar
doubleclick
Drive SDK
Drivers
ecommerce
ecosistema
elections
elizalde
Emoticons
emprendedores
empresas
engagement
english
Enhanced Campaigns
enterprise
eventos
Events
evolución de aplicaciones
Excel
ExpertosDicen
Faas
Family
FanBridge
FCM
FCP
Featured
fido
find people
Fintech
firebase
Firebase Cloud Messaging
firebase summit
flu trends
Flutter
Flutter 1.0
flutter 1.7
flutter developers
Flutter Live
FlutterLive
FoundersLab
Freebase
Fuction
Fuctions
Full-Stack
functional programming
G Suite Dev Show
G+
g+ goto gal
G+GotoGal
GAE
game
games
GCloud
gcm
GCP
GCS
GDA
GDE
GDG
GDH
GDL
GDLevent
GDS
Get Inspired
get.app
GitHub
GLP
gmail
golang
GOMO
Google
Google Accelerator
Google AdMob SDK
Google AdWords
Google Analytics
Google APIS
Google App Engine
Google Apps
Google Apps Script
Google Art Project
Google Assistant
google calendar
google cast
Google Charts
Google Chrome
Google Cloud
Google Cloud Console
Google Cloud Messaging
Google Cloud Next
Google Cloud Platform
Google Cloud Platform Newsletter
google cloud platforn
Google Cloud Storage
google code-in
Google Compute Engine
Google Dataset
Google Developer Groups
google developers
Google Developers Academy
google developers expert
Google Developers Hackademy
google dns
Google Drawings
Google Drive
Google Earth
Google for games
Google Forms
google geo
Google Home
google i/o
google i/o extended
google io
Google Keep
Google Kubernetes Engine
Google Launchapad
Google Launchpad
Google Maps
google maps coordinate
Google Maps Platform
Google Mexico
Google Nose
google now
Google Person Finder
google places api
Google Play
Google Play Books
Google Play Developer API
google play games
Google Play Movies
Google Play Protect
Google Play Services
Google Plus
Google Science Fair
google search
Google Sheets
google sign in
Google Top Geek
Google+
Google+ Communities
Google+ Hangouts
google+ sign-in
GoogleAPI
googlecloud storage
GoogleCloudPlatform
googledevs
GooglePlay
Googleplex
Goolge Lunchpad
GTG
Hackademy
hackers
Haiko
Haití
hangouts
Hangouts Remote Desktop
hardcode
Heello
honeycomb
HTML
HTML5
HTTPS
I/O
IA
IAM
IETF
IFAI
in app purchases
in-app
ingles
Ingress
instagram
integración de soluciones
interactive post
Interesante
International
International Women’s Day
IO
io15
io18
io19
iOS
IoT
istio
IU
IVR
J2EE
java
JavaScript
jelly bean
JS
JSON
Juegos
juegos html5
Kit ML
Knative
kotlin
kUBERNATES
Kubernetes
LATAM
latamRegionSur
Launchpad
Launchpad Studio
Lenovo Mirage Solo
lightbox
linux
lucero galindo
machine learning
Made with Code
Mapdata
Mapeo
maps
Maps Ad Unit
Maps API
Maps Engine
Market
Marketing
Marshmallow
MATERIAL DESIG
Material Design
mejores apps 2013
México
michelle marie
MIT
MIT Global Start-up Labs
MIT-AITI
ML
ML Kit
mobile
monetizar
mongoDB
MOOC
Motorola
Mountain View
móvil
MQTT
mr.white
mTLS
natalie villalobos
Navigation
NBA JAM
NES
Next Big Sound
Next Level
nfc
Niantic
Nik
NINTENDO
node.js
NoSQL
nube
OAuth2
Objective-C
OClock
open source
OPenApi
OS
OSS
Paas
PageSpeed
PagesSpeed
parallel18
patrones
patters
performance
permisos
Pipeline API
Pixability
pixel
Píxel
play
Play Console
Playtime
Podcast
pollito pio
Polymer
por lote
Posse
Prediction API
primer
Producto
programación
Propositos
Protocol Buffers
proyecto 20%
Push API
PYMES
python
Q
Q4
quickoffice
Rasberry Pi Zero WH
Raspberry Pi
Realtime
Reflectly
register
Release
Resources
robots.txt
Safe
SDK
Search
Security
seedbank
seguridad
SEO
servidores
Showyou
sign-in
SNES
SO
social media
Spain
SpLATAM
SQL
SQLite
Start
startup grind
Startup Launch
startup weekend
startup weekend for the planet
startupbus
startups
StayAtHome
story
Street View
subtitles
success
sw
SyScan
tablet
Tablet Optimization Tips
tabletas
takeaction
Tango
tendencias 2013
TensorFlow Developer Summit
testing
TextView
TF JAM
The Garage
The Venture City
tips G+
tips gmail
TLD
TLS
Top Experts
Top Geek
top level domain
TopExpert
topics
traducciones
Transparency Report
triggers
Tubular Labs
twilio
Tyka
TypeScript
UAC
udacity
ui
Umbrales
UNAM
unity
Unity3D
universal search
UX
Vector
VectorDrawable
video juegos
vidIQ
ViewPager
Visual Progress
Voicekit
VPC
VR
VSCode
web
Web hosting
Web móvil
WebAssembly
with google
Wizdeo
WizTracker
Women at Google
Women Techmakers
workmanager
WTM
XKCD
XML
Yifat Cohen
youtube
YouTube Analytics API
YouTube API
YouTube Data API
YouTube One Channel
YouTube Player API
Archive
2024
sept
2023
nov
oct
sept
ago
jun
may
abr
mar
ene
2022
dic
nov
oct
sept
ago
jul
jun
may
abr
mar
feb
ene
2021
dic
nov
oct
sept
ago
jul
jun
may
abr
mar
feb
2020
dic
nov
oct
sept
ago
jul
jun
may
abr
mar
feb
ene
2019
dic
nov
oct
sept
ago
jun
may
abr
mar
feb
ene
2018
dic
nov
oct
sept
ago
jul
jun
may
abr
mar
feb
2017
nov
sept
ago
jul
jun
may
abr
ene
2016
nov
oct
sept
ago
jul
jun
may
abr
mar
feb
ene
2015
dic
nov
oct
sept
ago
jul
jun
may
abr
mar
feb
ene
2014
dic
oct
sept
ago
jul
jun
may
abr
mar
feb
ene
2013
dic
nov
oct
ago
jul
jun
may
abr
mar
feb
ene
2012
dic
nov
oct
sept
ago
jul
2011
nov
oct
may
mar
2010
dic
nov
oct
sept
ago
jul
jun
may
abr
mar
feb
ene
2009
dic
nov
sept
ago
jul
jun
may
abr
mar
feb
ene
2008
oct
sept
ago
jul
jun
may
abr
mar
feb
ene
2007
dic
Feed
Desarrolladores
Eventos y Comunidad
Casos Destacados
Dicen los Expertos
Google Accelerator