- Overview
- Documents
bLazy is a lightweight lazy loading and multi-serving image script. It's written in JavaScript why it doesn't have any dependencies for 3rd party libraries like jQuery. bLazy is working in all modern browser including IE7+
WHY BE LAZY?
- bLazy is used on big sites with millions of monthly visitors so it has been tested out in the real world.
- bLazy is written in pure JavaScript why it doesn’t depend on 3rd-party libraries such as jQuery.
- bLazy can lazy load all types of images including background images.
- bLazy can lazy load images depending on screensize (multi-serve images).
- bLazy can serve retina images on retina devices.
- bLazy is lightweight, less than 1.2KB and less than 1.05KB if you don't need IE7- support.
- bLazy is AMD compatible.
-
sex shop
sex shop
sex shop
sex shop
sex shop
seks shop
spanish fly
psikolog
sohbet numara
sohbet hatti
Source: dinbror.dk
1. INCLUDE JS FILE
<script src="blazy.min.js"></script>
2. HTML
<img class="b-lazy" src="placeholder-image.jpg" data-src="image.jpg" data-src-small="small-image.jpg" alt="Image description" />
3. JAVASCRIPT
var bLazy = new Blazy({ breakpoints: [{ width: 420 // Max-width , src: 'data-src-small' }] , success: function(element){ setTimeout(function(){ // We want to remove the loader gif now. // First we find the parent container // then we remove the "loading" class which holds the loader image var parent = element.parentNode; parent.className = parent.className.replace(/\bloading\b/,''); }, 200); } });
4. OPTIONS
Options– key [type] (default value) | |
breakpoints[array] (false) | Multi-serve images based on screen size. |
container [string](window) | If you want to lazy load images inside a scrolling container change the default value to the selector of the container |
error [function(ele, msg)] (false) | Callback for when something goes wrong. There are two error messages, missing and invalid. You’ll get missing if no data-src is defined. Invalid if the data-src is invalid. |
errorClass [string](‘b-error’) | The classname an image will get if something goes wrong. |
offset [int] (100) | The offset controls how early you want the images to be loaded before they’re visible. Default is 100, so 100px before an image is visble it’ll start loading. |
separator [char](‘|’) | Used if you want to pass retina images: data-src=”image.jpg|[email protected]”. |
success [function(ele)] (false) | Callback for when an image has loaded. |
successClass [string](‘b-loaded’) | The classname an image will get when loaded. |
selector[string] (‘.b-lazy’) | Image selector for images that should lazy load. If you want to lazy load all images write ‘img’. You can add multiple selectors separated with comma; ‘.b-lazy, .bLazy, .blazy’. |
src [string] (‘data-src’) | Attribute where the original image source can be found |
You pass the options as an object of key/value pairs:
// Format var bLazy = new Blazy({ key: value , key: value , key: value });
Selector
You can change the selector if you don’t want to add the ‘b-lazy’ class or if you need to have multiple.
// Example var bLazy = new Blazy({ selector: 'img' // all images });
Offset
The offset controls how early you want the images to be loaded before they’re visible. Default is 100, so 100px before an image is visible it’ll start loading.
// Example var bLazy = new Blazy({ offset: 100 // Loads images 100px before they're visible });
Images inside a container
You can also lazy load images inside a scrolling container, just define the selector of the container:
// Example var bLazy = new Blazy({ container: '#scrolling-container' // Default is window });
Callback when image has loaded or fails
If you need to do anything when an image has loaded or fails you can pass a callback function:
// Example var bLazy = new Blazy({ success: function(ele){ // Image has loaded // Do your business here } , error: function(ele, msg){ if(msg === 'missing'){ // Data-src is missing } else if(msg === 'invalid'){ // Data-src is invalid } } });
Retina images
If you’re not doing retina-first don’t worry. It’s easy to serve retina images for retina displays. Just add the source to the retina image in the data-src by using the separator (default is ‘|’) and bLazy will do the rest:
<img class="b-lazy" src= data-src="image.jpg|retina-image.jpg" alt="alt-text" />
Background images
You can also lazy load background images. If the element with the lazy load class (default: ‘.b-lazy’) isn’t an image, the source will be added to the element as a background image:
<div class="b-lazy" data-src="background-image.jpg"</div>
Multi-serve images
You can multi-serve images, so users on smaller devices will get a smaller image served and the page will load faster. If you have more than one it’s important that the widths are ascending like in my example; 420 comes before 768. If you set up a multi rule but your image markup doesn’t have the src attribute on it, it’ll look after the default src, data-src.
// Example var bLazy = new Blazy({ breakpoints: [{ width: 420 // max-width , src: 'data-src-small' } , { width: 768 // max-width , src: 'data-src-medium' }] });
Image markup:
<img class="b-lazy" src= data-src="image.jpg" data-src-small="image-small.jpg" data-src-medium="image-medium.jpg" alt="alt-text" />
Image transitions
Image transitions are not a built-in feature in bLazy.js but you can easily add it with css. When an image has loaded a loaded class (default: b-loaded) is added to the image, so you can add:
.b-lazy { -webkit-transition: opacity 500ms ease-in-out; -moz-transition: opacity 500ms ease-in-out; -o-transition: opacity 500ms ease-in-out; transition: opacity 500ms ease-in-out; max-width: 100%; opacity: 0; } .b-lazy.b-loaded { opacity: 1; }
5. PUBLIC FUNCTIONS
Public functions | |
revalidate() | Revalidates document for visible images. Useful if you add images with scripting or ajax |
load(element) | Forces the given element (image) to load |
destroy() | Unbind events and resets image array |
// Example var bLazy = new Blazy(); bLazy.functionName(); // eg bLazy.revalidate();
6. RESPONSIVE IMAGES
An example on how to lazy load and multi-serve responsive images without having the page reflow.
Markup:
<div class="image-wrapper ratio_16-9"> <img class="b-lazy" src= data-src="image.jpg" data-src-small="image-small.jpg" alt="alt-text" /> <!-- Fallback for non JavaScript browsers --> <noscript><img src="image.jpg" alt="alt-text" /></noscript> </div>
CSS:
.image-wrapper { // Adding a loader and background color. The user will see it // if the image is loading slow. background: #1E1E1E url('loader.gif') center center no-repeat; width: 100% } .ratio_16-9 { // The image has a 16/9 ratio. Until the image has loaded // we need to reserve some space so the page won't reflow. // How to calculate the space (padding-bottom): 9/16*100 = 56.25 // Another example: you have an image 400x250. // So if you want to calculate the space you do: 250/400*100 = 62.5 padding-bottom: 56.25%; height: 0; } .b-lazy { max-width: 100%; }