O responsive lazyload image, é um componente para dojotoolkit que pemite carregar imagens sobre demanda e com a imagem para determinada resolução.
Com isso, é possível ter sites carregando muitas vezes mais rápido com a imagem correta, nada de redimencionar! :)
<picture data-lazy-alt="Alt da imagem" data-lazy>
<source data-lazy-media="(min-width: 320px)" data-lazy-src="http://placehold.it/320x480" data-lazy-width="320" data-lazy-height="480">
<source data-lazy-media="(min-width: 768px)" data-lazy-src="http://placehold.it/768x600/00ffff"
<noscript>
<img src="http://placehold.it/1200x600" alt="Alt da imagem" width="1200" height="600">
</noscript>
</picture>
ou com uma url base padrão
<picture data-lazy-alt="Alt da imagem" data-lazy-base="http://placehold.it/" data-lazy>
<source data-lazy-media="(min-width: 320px)" data-lazy-src="320x480" data-lazy-width="320" data-lazy-height="480">
<source data-lazy-media="(min-width: 768px)" data-lazy-src="768x600/00ffff"
<noscript>
<img src="http://placehold.it/1200x600" alt="Alt da imagem" width="1200" height="600">
</noscript>
</picture>
ou utilizando a tag lazy
<lazy data-lazy-alt="Alt da imagem" data-lazy-base="http://placehold.it/">
<source data-lazy-media="(min-width: 320px)" data-lazy-src="320x480" data-lazy-width="320" data-lazy-height="480">
<source data-lazy-media="(min-width: 768px)" data-lazy-src="768x600/00ffff"
<noscript>
<img src="http://placehold.it/1200x600" alt="Alt da imagem" width="1200" height="600">
</noscript>
</lazy>
<picture data-lazy-alt="Alt da imagem" data-lazy></picture>
<noscript>
<img src="http://placehold.it/1200x600" alt="Alt da imagem" width="1200" height="600">
</noscript>
É possível adicionar qualquer quantidade de imagens, desde que siga um padrãozinho:
<source data-lazy-media="(min-width: 320px)" data-lazy-src="http://placehold.it/320x480" data-lazy-width="320" data-lazy-height="480">
- data-lazy-media : Este é o parâmetro de media querie
- data-lazy-min : Este parâmetro é uma forma masi simples de definir a media querie para min-width
- data-lazy-max : Este parâmetro é uma forma masi simples de definir a media querie para max-width
- data-lazy-src : Imagem para este media
- data-lazy-width: Largura da imagem, isso melhora muito a experiência do usuário
- data-lazy-height: Altura da imagem, isso melhora muito a experiência do usuário
var dojoConfig = {
packages: [{
name: 'lazy',
location: '/bower_components/lazy/dist/scripts/responsive-lazyload'
}, {
name: 'onx',
location: '/bower_components/onx/src'
}, {
name: 'mout',
location: '/bower_components/mout/src'
}]
}
require(['lazy/responsive-lazyload']);
require(['lazy/responsive-lazyload', 'dojo/query'], function(lazy, query){
// adicionando novas imagens
lazy.add( query('picture[data-lazy]') );
lazy.render();
});
- add : adiciona novas imagens
- render : forca o render de todas as imagens que estiverem dentro do viewport
"dependencies": {
"dojo": "~1.9",
"dojox": "~1.9",
"dijit": "~1.9",
"matchmedia": "~0.1.0",
"onx": "git://github.com/eduardo-matos/onx.git",
"mout": "~0.7.1"
}
$ bower install
Fala comigo! email: allan@allanbatista.com.br