forked from joshje/Responsive-Enhance
-
Notifications
You must be signed in to change notification settings - Fork 0
/
responsive-enhance.js
27 lines (26 loc) · 1.21 KB
/
responsive-enhance.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
var addEvent=function(){return document.addEventListener?function(a,c,d){if(a&&a.nodeName||a===window)a.addEventListener(c,d,!1);else if(a&&a.length)for(var b=0;b<a.length;b++)addEvent(a[b],c,d)}:function(a,c,d){if(a&&a.nodeName||a===window)a.attachEvent("on"+c,function(){return d.call(a,window.event)});else if(a&&a.length)for(var b=0;b<a.length;b++)addEvent(a[b],c,d)}}();
var responsiveEnhance = function(img, width, monitor) {
console.log(img);
if (img.length) {
for (var i=0, len=img.length; i<len; i++) {
responsiveEnhance(img[i], width, monitor);
}
} else {
if (((' '+img.className+' ').replace(/[\n\t]/g, ' ').indexOf(' large ') == -1) && img.clientWidth > width) {
var fullimg = new Image();
addEvent(fullimg, 'load', function(e) {
img.src = this.src;
img.className += ' large';
});
fullimg.src = img.getAttribute('data-fullsrc');
}
}
if (monitor != false) {
addEvent(window, 'resize', function(e) {
responsiveEnhance(img, width, false);
});
addEvent(img, 'load', function(e) {
responsiveEnhance(img, width, false);
});
}
};