Browse Source

Echo 1.5.0

pull/34/head v1.5.0
Todd Motto 11 years ago
parent
commit
25273437e2
  1. 6
      README.md
  2. 86
      dist/echo.js
  3. 4
      dist/echo.min.js
  4. 5
      package.json
  5. 84
      src/echo.js

6
README.md

@ -30,12 +30,12 @@ Using Echo.js is simple, just add the image you wish to load to a `data-echo` a
The `init()` API takes a few options The `init()` API takes a few options
#### offset #### offset
Type: `Integer` Default: `0` Type: `Number|String` Default: `0`
The `offset` option allows you to specify how far below the viewport you want Echo to _begin_ loading your images. If you specify `0`, Echo will load your image as soon as it is visible in the viewport, if you want to load _1000px_ below the viewport, use `1000`. The `offset` option allows you to specify how far below the viewport you want Echo to _begin_ loading your images. If you specify `0`, Echo will load your image as soon as it is visible in the viewport, if you want to load _1000px_ below the viewport, use `1000`.
#### throttle #### throttle
Type: `Integer` Default: `250` Type: `Number|String` Default: `250`
The throttle is managed by an internal function that prevents performance issues from continuous firing of `window.onscroll` events. Using a throttle will set a small timeout when the user scrolls and will keep throttling until the user stops. The default is `250` milliseconds. The throttle is managed by an internal function that prevents performance issues from continuous firing of `window.onscroll` events. Using a throttle will set a small timeout when the user scrolls and will keep throttling until the user stops. The default is `250` milliseconds.
@ -53,7 +53,7 @@ Using `render()` is also throttled, which means you can bind it to a `window.onr
Drop your files into your required folders, make sure you're using the file(s) from the `dist` folder, which is the compiled production-ready code. Ensure you place the script before the closing `</body>` tag so the DOM tree is populated when the script runs. Drop your files into your required folders, make sure you're using the file(s) from the `dist` folder, which is the compiled production-ready code. Ensure you place the script before the closing `</body>` tag so the DOM tree is populated when the script runs.
## Configuring Echo ## Configuring Echo
Add the image that needs to load when visible in a `data-echo` attribute: Add the image that needs to load when it's visible inside the viewport in a `data-echo` attribute:
```html ```html
<img src="img/blank.gif" alt="Photo" data-echo="img/photo.jpg"> <img src="img/blank.gif" alt="Photo" data-echo="img/photo.jpg">

86
dist/echo.js vendored

@ -1,52 +1,102 @@
/*! Echo v1.4.0 | (c) 2013 @toddmotto | MIT license | github.com/toddmotto/echo */ /*! Echo v1.5.0 | (c) 2014 @toddmotto | MIT license | github.com/toddmotto/echo */
window.Echo = (function (window, document, undefined) { window.Echo = (function (global, document, undefined) {
'use strict'; 'use strict';
var store = [], offset, throttle, poll; /**
* store
* @type {Array}
*/
var store = [];
var _inView = function (el) { /**
var coords = el.getBoundingClientRect(); * offset, throttle, poll vars
return ((coords.top >= 0 && coords.left >= 0 && coords.top) <= (window.innerHeight || document.documentElement.clientHeight) + parseInt(offset)); */
var offset, throttle, poll;
/**
* _inView
* @private
* @param {Element} element Image element
* @returns {Boolean} Is element in viewport
*/
var _inView = function (element) {
var coords = element.getBoundingClientRect();
return ((coords.top >= 0 && coords.left >= 0 && coords.top) <= (window.innerHeight || document.documentElement.clientHeight) + offset);
}; };
/**
* _pollImages Loop through the images if present
* or remove all event listeners
* @private
*/
var _pollImages = function () { var _pollImages = function () {
for (var i = store.length; i--;) { var length = store.length;
var self = store[i]; if (length > 0) {
if (_inView(self)) { for (var i = 0; i < length; i++) {
self.src = self.getAttribute('data-echo'); var self = store[i];
store.splice(i, 1); if (self && _inView(self)) {
self.src = self.getAttribute('data-echo');
store.splice(i, 1);
length = store.length;
i--;
}
}
} else {
if (document.removeEventListener) {
global.removeEventListener('scroll', _throttle);
} else {
global.detachEvent('onscroll', _throttle);
} }
clearTimeout(poll);
} }
}; };
/**
* _throttle Sensible event firing
* @private
*/
var _throttle = function () { var _throttle = function () {
clearTimeout(poll); clearTimeout(poll);
poll = setTimeout(_pollImages, throttle); poll = setTimeout(_pollImages, throttle);
}; };
/**
* init Module init function
* @param {Object} [obj] Passed in Object with options
* @param {Number|String} [obj.throttle]
* @param {Number|String} [obj.offset]
*/
var init = function (obj) { var init = function (obj) {
var nodes = document.querySelectorAll('[data-echo]'); var nodes = document.querySelectorAll('[data-echo]');
var opts = obj || {}; var opts = obj || {};
offset = opts.offset || 0; offset = parseInt(opts.offset || 0);
throttle = opts.throttle || 250; throttle = parseInt(opts.throttle || 250);
for (var i = 0; i < nodes.length; i++) { for (var i = 0; i < nodes.length; i++) {
store.push(nodes[i]); store.push(nodes[i]);
} }
_throttle(); _pollImages();
if (document.addEventListener) { if (document.addEventListener) {
window.addEventListener('scroll', _throttle, false); global.addEventListener('scroll', _throttle, false);
global.addEventListener('load', _throttle, false);
} else { } else {
window.attachEvent('onscroll', _throttle); global.attachEvent('onscroll', _throttle);
global.attachEvent('onload', _throttle);
} }
}; };
/**
* return Public methods
* @returns {Object}
*/
return { return {
init: init, init: init,
render: _throttle render: _pollImages
}; };
})(window, document); })(this, document);

4
dist/echo.min.js vendored

@ -1,2 +1,2 @@
/*! Echo v1.4.0 | (c) 2013 @toddmotto | MIT license | github.com/toddmotto/echo */ /*! Echo v1.5.0 | (c) 2014 @toddmotto | MIT license | github.com/toddmotto/echo */
window.Echo=function(a,b){"use strict";var c,d,e,f=[],g=function(d){var e=d.getBoundingClientRect();return(e.top>=0&&e.left>=0&&e.top)<=(a.innerHeight||b.documentElement.clientHeight)+parseInt(c)},h=function(){for(var a=f.length;a--;){var b=f[a];g(b)&&(b.src=b.getAttribute("data-echo"),f.splice(a,1))}},i=function(){clearTimeout(e),e=setTimeout(h,d)},j=function(e){var g=b.querySelectorAll("[data-echo]"),h=e||{};c=h.offset||0,d=h.throttle||250;for(var j=0;j<g.length;j++)f.push(g[j]);i(),b.addEventListener?a.addEventListener("scroll",i,!1):a.attachEvent("onscroll",i)};return{init:j,render:i}}(window,document); window.Echo=function(a,b){"use strict";var c,d,e,f=[],g=function(a){var d=a.getBoundingClientRect();return(d.top>=0&&d.left>=0&&d.top)<=(window.innerHeight||b.documentElement.clientHeight)+c},h=function(){var c=f.length;if(c>0)for(var d=0;c>d;d++){var h=f[d];h&&g(h)&&(h.src=h.getAttribute("data-echo"),f.splice(d,1),c=f.length,d--)}else b.removeEventListener?a.removeEventListener("scroll",i):a.detachEvent("onscroll",i),clearTimeout(e)},i=function(){clearTimeout(e),e=setTimeout(h,d)},j=function(e){var g=b.querySelectorAll("[data-echo]"),j=e||{};c=parseInt(j.offset||0),d=parseInt(j.throttle||250);for(var k=0;k<g.length;k++)f.push(g[k]);h(),b.addEventListener?(a.addEventListener("scroll",i,!1),a.addEventListener("load",i,!1)):(a.attachEvent("onscroll",i),a.attachEvent("onload",i))};return{init:j,render:h}}(this,document);

5
package.json

@ -1,10 +1,9 @@
{ {
"name": "Echo", "name": "Echo",
"version": "1.4.0", "version": "1.5.0",
"homepage": "https://github.com/toddmotto/echo", "homepage": "https://github.com/toddmotto/echo",
"author": "Todd Motto", "author": "Todd Motto",
"year" : "2013", "description": "Lazy-loading with data-* attributes, offset and throttle options",
"description": "Lazy-loading with data-* attributes, offsets and throttle options",
"author": { "author": {
"name": "Todd Motto", "name": "Todd Motto",
"email": "todd@toddmotto.com", "email": "todd@toddmotto.com",

84
src/echo.js

@ -1,51 +1,101 @@
window.Echo = (function (window, document, undefined) { window.Echo = (function (global, document, undefined) {
'use strict'; 'use strict';
var store = [], offset, throttle, poll; /**
* store
* @type {Array}
*/
var store = [];
var _inView = function (el) { /**
var coords = el.getBoundingClientRect(); * offset, throttle, poll vars
return ((coords.top >= 0 && coords.left >= 0 && coords.top) <= (window.innerHeight || document.documentElement.clientHeight) + parseInt(offset)); */
var offset, throttle, poll;
/**
* _inView
* @private
* @param {Element} element Image element
* @returns {Boolean} Is element in viewport
*/
var _inView = function (element) {
var coords = element.getBoundingClientRect();
return ((coords.top >= 0 && coords.left >= 0 && coords.top) <= (window.innerHeight || document.documentElement.clientHeight) + offset);
}; };
/**
* _pollImages Loop through the images if present
* or remove all event listeners
* @private
*/
var _pollImages = function () { var _pollImages = function () {
for (var i = store.length; i--;) { var length = store.length;
var self = store[i]; if (length > 0) {
if (_inView(self)) { for (var i = 0; i < length; i++) {
self.src = self.getAttribute('data-echo'); var self = store[i];
store.splice(i, 1); if (self && _inView(self)) {
self.src = self.getAttribute('data-echo');
store.splice(i, 1);
length = store.length;
i--;
}
}
} else {
if (document.removeEventListener) {
global.removeEventListener('scroll', _throttle);
} else {
global.detachEvent('onscroll', _throttle);
} }
clearTimeout(poll);
} }
}; };
/**
* _throttle Sensible event firing
* @private
*/
var _throttle = function () { var _throttle = function () {
clearTimeout(poll); clearTimeout(poll);
poll = setTimeout(_pollImages, throttle); poll = setTimeout(_pollImages, throttle);
}; };
/**
* init Module init function
* @param {Object} [obj] Passed in Object with options
* @param {Number|String} [obj.throttle]
* @param {Number|String} [obj.offset]
*/
var init = function (obj) { var init = function (obj) {
var nodes = document.querySelectorAll('[data-echo]'); var nodes = document.querySelectorAll('[data-echo]');
var opts = obj || {}; var opts = obj || {};
offset = opts.offset || 0; offset = parseInt(opts.offset || 0);
throttle = opts.throttle || 250; throttle = parseInt(opts.throttle || 250);
for (var i = 0; i < nodes.length; i++) { for (var i = 0; i < nodes.length; i++) {
store.push(nodes[i]); store.push(nodes[i]);
} }
_throttle(); _pollImages();
if (document.addEventListener) { if (document.addEventListener) {
window.addEventListener('scroll', _throttle, false); global.addEventListener('scroll', _throttle, false);
global.addEventListener('load', _throttle, false);
} else { } else {
window.attachEvent('onscroll', _throttle); global.attachEvent('onscroll', _throttle);
global.attachEvent('onload', _throttle);
} }
}; };
/**
* return Public methods
* @returns {Object}
*/
return { return {
init: init, init: init,
render: _throttle render: _pollImages
}; };
})(window, document); })(this, document);

Loading…
Cancel
Save