class: center, middle # **Responsive Images:** Lessons Learned .small[[CASCADE BOS meet up @Bocoup](http://www.meetup.com/cascadebos/events/225309830/) | September 22, 2015] by Daigo Fujiwara | [daigofuji.github.io/responsive-images](http://daigofuji.github.io/responsive-images/#1) --- class: center, middle ## Daigo Fujiwara Front-end Web Developer, Harvard Business Review Follow along: [daigofuji.github.io/responsive-images](http://daigofuji.github.io/responsive-images/#1) --- class: center, middle, inverse # Responsive Web Design Redesign of hbr.org in November 2014 --- class: center, middle, big-img, gray data:image/s3,"s3://crabby-images/78a81/78a8195c7cb66720c1a293d7de31ac433578883a" alt="img" --- class: center, middle ## Not a new idea --- class: center, middle, big-img, white [data:image/s3,"s3://crabby-images/3738e/3738e04242b358d4ad1a1ba534c2ef794b9ea00a" alt="img"](http://alistapart.com/article/responsive-web-design) --- class: center, middle Media Query ```css @media (min-width:500px) { ... } ``` Flexible Images ```css img { max-width: 100%; } ``` and Fluid Grids --- class: center, middle # **PREMIUM** --- class: center, middle (What we thought) #Premium
=
**High Resolution** --- class: center, middle, big-img, gray data:image/s3,"s3://crabby-images/4add1/4add1604a272dc7b90b3f0da3426bb9d1ed8dbff" alt="Example of article page" --- class: center, middle, big-img, white data:image/s3,"s3://crabby-images/d184b/d184bc769b97cce9265db7889026d4fba1129157" alt="Example of article page" --- class: center, middle, big-img, gray data:image/s3,"s3://crabby-images/3f349/3f349821ddbdf9d57520adcf9b8d95a8291cf365" alt="Example of article page" --- class: center, middle, big-img, gray data:image/s3,"s3://crabby-images/a132d/a132de5c10612a0d23182ec032726a3d32e868de" alt="Example of article page" --- class: center, middle, big-img, white data:image/s3,"s3://crabby-images/6dac1/6dac129f2e78f675cedeaf3beb0624cefd2fb0e3" alt="img" .small["bite off more than one can chew"] --- class: center, middle #Premium
=
**RIGHT Resolution** --- class: center, middle, inverse # Tools and references --- class: center, middle, white data:image/s3,"s3://crabby-images/9d286/9d2869935fbd646f9de676baaf2d26b14f89791d" alt="img" [WebpageTest.org](http://www.webpagetest.org/) --- class: center, middle, white data:image/s3,"s3://crabby-images/f312b/f312b34ef18902ed73f7c2d6b92b52a43058b2d6" alt="img" [Google Page Insights](https://developers.google.com/speed/pagespeed/insights/) --- class: center, middle, white data:image/s3,"s3://crabby-images/200e6/200e60322486516eea7e6f1fd818e79467317cf3" alt="img" [**Too Much Images**](https://github.com/addyosmani/tmi) (tmi for short) by [Addy Osmani](https://addyosmani.com/) --- class: center, middle, white data:image/s3,"s3://crabby-images/6039d/6039d2a681826c787ce9a9c820f92698d08fe997" alt="img" [**HTTP Archive's Stats**](http://httparchive.org/interesting.php) --- class: center, middle, white data:image/s3,"s3://crabby-images/b09fd/b09fd2cec02ac343f6bfc504a9deaed96b39f359" alt="img" [**BrowserDiet.com**](http://browserdiet.com/en/) Community-driven performance guide --- class: center, middle, inverse # Responsive Images --- class: center, middle, white [data:image/s3,"s3://crabby-images/1f852/1f8522714f5ee347ec31d5d039f9fb0836a27c2d" alt="img"](http://responsiveimages.org/) RICG (Responsive Issues Community Group) and Mat "Wilto" Marquis to the rescue. data:image/s3,"s3://crabby-images/f182b/f182b413d3a71a2ab91a1dd395afdd5e90e303cb" alt="img" --- class: middle ### Examples - media query - `srcset` attribute - `srcset` and `sizes` attributes - `picture` tag --- class: center, middle, inverse # Media Query ```css @media (min-width:500px) { ... } ``` --- class: center, middle, white data:image/s3,"s3://crabby-images/f408f/f408f598cc788fef0c00af0f1578e29434b82c2a" alt="img" --- class: middle ### Demo - [examples/mediaquery.html](http://daigofuji.github.io/responsive-images/examples/mediaquery.html) - [bit.ly/1Kxiflb](http://bit.ly/1Kxiflb) - [Test using ish](http://bradfrost.com/demo/ish/?url=http%3A%2F%2Fdaigofuji.github.io%2Fresponsive-images%2Fexamples%2Fmediaquery.html) - [view source on github](https://github.com/daigofuji/responsive-images/blob/gh-pages/examples/mediaquery.html) --- class: center, middle, inverse # srcset ```html
``` --- class: center, middle, white data:image/s3,"s3://crabby-images/94466/94466fd123b7af424beadc907e0732afc73549c1" alt="img" --- class: center, middle ```html
``` ### Web Hypertext Application Technology Working Group’s (WHATWG) [Living Standard](https://html.spec.whatwg.org/multipage/embedded-content.html) --- class: middle ```html
``` An `img` element represents an image. The image referenced by the `src` and `srcset` attributes is the content to be embedded. The `srcset` attribute details the image candidates, from which the User Agent can select the most suitable image. --- class: middle Example **Retina Display image swap** ```html
``` - If your browser does not support srcset, you will see gray (default) 100x100 - If srcset is supported but is not retina, red 100x100 - If srcset is supported and is retina, blue 200x200 --- class: middle ### Demo - [examples/srcset.html](http://daigofuji.github.io/responsive-images/examples/srcset.html) - [bit.ly/1FrQYU9](http://bit.ly/1FrQYU9) - [view source on github](https://github.com/daigofuji/responsive-images/blob/gh-pages/examples/srcset.html) What to expect: - If your browser does not support srcset, you will see gray (default) 100x100 - If srcset is supported but is not retina, red 100x100 - If srcset is supported and is retina, blue 200x200 --- class: center, middle `2x` in srcset is a **descriptor**. Each image candidate string inside `srcset` must have at least one of the descriptors. You can also use w-descriptor like `200w` ("this image is 200 pixel wide") You can omit 1x in the example, too. Like: ```html
``` --- class: center, middle, inverse # srcset and sizes ```html
``` --- class: middle The `sizes` attribute can be used to specify additional context about the intended embed/render size of the image relative to the viewport width. > WHATWG's [Living Standard](https://html.spec.whatwg.org/multipage/embedded-content.html) --- class: center, middle, gray Great read: [Srcset and sizes](https://ericportis.com/posts/2014/srcset-sizes/) by Eric Portis data:image/s3,"s3://crabby-images/f9013/f9013952dfc06bec8a9523a268cc0bbbd5337ccf" alt="img" --- class: center, middle, gray data:image/s3,"s3://crabby-images/9a061/9a0613e7a07affc055ae90386dca5fe273c5ab9d" alt="img" .small[from [Srcset and sizes](https://ericportis.com/posts/2014/srcset-sizes/) by Eric Portis] --- class: center, middle ### Example **HBR Article Page** Image is 100% of the viewport width (100vw) up to 1024px (Media query breakpoint). Then it is 83% of the viewport width (10 out of 12 column) ```
``` --- Demo - [examples/srcset-sizes.html](http://daigofuji.github.io/responsive-images/examples/srcset-sizes.html) - [bit.ly/1PoYgbJ](http://bit.ly/1PoYgbJ) - [Test using ish](http://bradfrost.com/demo/ish/?url=http%3A%2F%2Fdaigofuji.github.io%2Fresponsive-images%2Fexamples%2Fsrcset-sizes.html) - [view source on github](https://github.com/daigofuji/responsive-images/blob/gh-pages/examples/srcset-sizes.html) --- class: center, middle, inverse # Picture tag --- class: middle ```html
``` --- class: middle If the parent is a `picture` element, then any previous sibling source element’s `srcset` attributes may also determine the embedded content. > WHATWG's [Living Standard](https://html.spec.whatwg.org/multipage/embedded-content.html) --- class: center, middle, white data:image/s3,"s3://crabby-images/5f56c/5f56c3ba4bb573b45e09899c6de255a06222f095" alt="img" --- class: center, middle ### Use `picture` _only_ if you're doing art direction — otherwise, `srcset/sizes` are the way to go. > -- Wilto --- class: center, middle ## Fallback Browsers that do not support/understand `srcset` will just continue to use the `src` element, and those browsers that do support `srcset` can use its value instead. --- class: center, middle, white [**Picturefill** Polyfill](https://scottjehl.github.io/picturefill/) by Scott Jehl data:image/s3,"s3://crabby-images/ffce1/ffce18390530b47a1e4adfd2d554432c2ca696f4" alt="img" --- class: center, middle Last but not least... ## What about images? --- class: center, middle, inverse # Tools for **automation** --- class: center, middle, white [RICG Responsive images plugin](https://wordpress.org/plugins/ricg-responsive-images/) for WordPress by Tim Evko et al data:image/s3,"s3://crabby-images/ee293/ee293fff2784a0e6b9b3570809f64856606658d0" alt="img" --- class: center, middle, white Sizes of images created using Responsive Images plugin .small[(Advanced Compression Option turned off)] data:image/s3,"s3://crabby-images/0356a/0356a755a60a549d0ebd8dee2f2bd1aa801e416f" alt="img" --- class: center, middle, white [Grunt Responsive Images](http://www.andismith.com/grunt-responsive-images/) by Andi Smith data:image/s3,"s3://crabby-images/a633d/a633d4051905215b031ab1ab35d3c6cb13c79ca0" alt="img" --- class: center, middle, white Sizes of images created using Grunt Responsive Images data:image/s3,"s3://crabby-images/6577a/6577af3492a517ed1a627706d3bfcca40be222aa" alt="img" This [how to by Addy Osmani](http://addyosmani.com/blog/generate-multi-resolution-images-for-srcset-with-grunt/) was helpful --- class: middle, center **Thank you!** data:image/s3,"s3://crabby-images/6dac1/6dac129f2e78f675cedeaf3beb0624cefd2fb0e3" alt="img" daigo@daigofujiwara.com [
@daigofuji](https://github.com/daigofuji) [
@daigofuji](https://twitter.com/DaigoFuji) data:image/s3,"s3://crabby-images/34e82/34e822324aabd9d9cd2cd295c7b2ff0d3ee47ba5" alt="img"