Máster en Diseño Web | Módulo III | Introducción I

Módulo III
Programación Frontend

Web Performance

¿Por qué es importante la performance en la web?

El usuario va navegando tan tranquilamente cuando...

“It’s time for us to treat performance as an essential design feature, not just as a technical best practice.”

El performance de la web no sólo afecta a la experiencia del usuario, sino también al SEO, y por supuesto al negocio.

Algunas estadísticas

Amazon

Aumenta sus ganancias en un 1% cada 100ms de mejora en la velocidad de descarga.


Yahoo

9% de aumento en el tráfico por cada 400ms de mejora.


Etsy

Cada 160k extra de peso en una página aumenta 12% la taza de rebote.

¿Qué podemos hacer para mejorar el performance?

“80-90% of the time spent by users waiting for pages to load is spent on the frontend, all the work that needs to be done after the HTML document has arrived.”

Performance 101

  • Reducir el peso de los recursos
  • Reducir las llamadas (requests) al servidor
  • Optimizar el cache

Reducir el peso de los recursos

Compresión Gzip

Los archivos de texto (.html, .css, .js, etc) pueden enviarse comprimidos desde el servidor para reducir su peso durante el viaje hasta el cliente. Esta reducción suele ser muy significativa.

Lo normal seria que nuestro servicio de host tenga activada la compresión gzip pero nunca está de más comprobarlo, y en caso de que no sea así, ponernos en contacto con ellos para que la activen.


gzipWTF

Check GZIP compression

Minificar archivos CSS y Js

Solemos escribir nuestro CSS y nuestro Javascript optimizado para su lectura, es decir, con una indentación y espaciado claro, comentarios, etc. Los ordenadores no necesitan esto para interpretarlos y es por eso que a la hora de subir un fichero al servidor podemos reducir bastante su peso si nos deshacemos de todo lo que no sea imprescindible.

Minificar archivos CSS y Js

Para ello existen varias herramientas. Por convención se suele diferenciar a los ficheros comprimidos con la extensión .min (Ej: styles.min.css)

CSS Compressor


Tambien podemos compilar el css comprimido directamente desde Sass.


sass style.scss:style.css --style compressed
        

El coste de las imágenes

“A picture is worth a thousand words, but its cost can be so much greater.”

Las imágenes son el recurso que más añade al peso total de la página.

Average Bytes per Page by Content Type

En móvil la proporción se mantiene.

Average Bytes per Page by Content Type

En móvil, el alto peso de las imágenes descargadas no sólo afecta la experiencia de usuario sino que puede tener un alto coste para su bolsillo dependiendo las condiciones de su plan de datos.

Un ejemplo: Performance is money, part 1: the end-user's wallet

Enlaces relacionados:

Optimización de imágenes manual

Guardar para web en Photoshop

  1. Elegir el formato adecuado
  2. Recortar la imágen al tamaño de final
  3. JPG: Elegir el nivel de compresion (75-70 óptimo)
  4. PNG: Limitar la paleta de colores
  5. Opcional: Activar la opción de descarga progresiva (JPG) / entrelazada (PNG)
  6. Quitar la metadata (sino la necesitamos)

Aplicaciones de optimización

Guardar SVG desde Illustrator

  • SVG Profiles: SVG 1.1 - Es una versión con buen soporte. Versiones anteriores no soportan algunas características como la transparencia.
  • Fonts Type: SVG - También podemos trazar el texto a outlines.
  • Subsetting: None (Use System Fonts) - Esta opción utilizará las fuentes del sistema ya que las fuentes SVG tienen problemas en algunos navegadores (FF & IE).
  • Images: Link - De esta manera mantendremos control sobre la compresión de los bitmap, aunque tendremos que cambiar la ruta a mano ya que Illustrator la apuntará a nuestro disco.

  • Uncheck 'Preserve Illustrator Editing Capabilities'.
  • Decimal places: 1 - Define los decimales que definen cada punto. Reducir el valor por defecto de 3 a 1 no produce ningun cambio visual pero reduce el tamaño del archivo considerablemente.
  • CSS Properties: Style Elements - Esta opción colocará los estilos dentro de un tag <style> al comienzo del svg.
  • El resto de las opciones las dejaremos como vienen por defecto.

Optimización automática de imágenes

JPG / GIF / PNG

SVG

Reducir la cantidad de recursos

Combinar CSS

Intentar tener un solo archivo Css. Gracias al @import Sass es sencillo creando un archivo principal que será el que se compile en css y sólo incluirá llamadas al resto de las hojas de estilo.


styles.scss => styles.css


@import 'base/normalize';
@import 'base/typography';
@import 'base/forms';
@import 'layout/grid';
@import 'layout/header';
@import 'layout/footer';
@import 'components/navigation';
@import 'components/slider';
        

Concatenar el Javascript

Con el Javascript podemos hacer lo mismo que el con el Css y combinar todos los archivos en uno solo, aunque no es tan sencillo. Hay que tener en cuenta más parametros como el orden de carga, la dependencia entre unos archivos y otros o qué scripts se necesitan ejecutar en qué momento.


Online JavaScript/CSS Compressor

La técnica de sprites proviene de la industria del videojuego y consiste en combinar diferentes imágenes en una sóla para luego acceder solo al fragmento de imágen que necesitamos en cada caso.

En web, esto nos permite tener una sola llamada al servidor en lugar de una por cada imágen.

Sprites por imágen


.icon {
    background-image: url('img/sprite.png');
    background-repeat: no-repeat;
    width: 24px;
    height: 24px;
}

.icon--alert    { background-position: 0px 0px; }
.icon--favorite { background-position: 0px -24px; }
.icon--share    { background-position: -48px -24x; }
.icon--mail     { background-position: 0 -48px; }
...
                

Sprites por css


[class^=icon-] {
    background-repeat: no-repeat;
}

.icon-github {
    background-image: url('...');
}

.icon-twitter {
    background-image: url('...');
}

.icon-facebook {
    background-image: url('...');
}
        

Bad practice? (“On Mobile, Data URIs are 6x Slower than Source Linking”)

Sprites SVG mediante <symbol>

Definición del SVG:


<svg xmlns="http://www.w3.org/2000/svg" style="display: none;">
    <symbol id="icon-twitter" viewBox="214.7 0 182.6 792">
        <!-- contenido del svg -->
    </symbol>
    <symbol id="icon-facebook" viewBox="0 26 100 48">
        <!-- contenido del svg -->
    </symbol>
</svg>
        

Uso con el svg inline en el HTML:


<svg class="twitter-icon">
  <use xlink:href="#icon-twitter"></use>
<svg>
        

Uso con el svg en un archivo externo:


<svg class="twitter-icon">
  <use xlink:href="ruta/externa/icons.svg#icon-twitter"></use>
<svg>
        

Herramientas de spriting

Web Performance