最近、jQueryを使ったJD.comの実装を以下のように勉強しました。
はimgタグのsrc2属性に割り当てられるデフォルトのアドレスで、表示時にsrc属性の値が割り当てられます。
function Lazyload(option) {
var settings = {
defObj: null,
defHeight: 0
};
settings = $.extend(settings, option || {});
var defHeight = settings.defHeight;
var defObj = (typeof settings.defObj == "object") ? settings.defObj.find("img") : $(settings.defObj).find("img");
var pageTop = 関数() {
return document.documentElement.clientHeight Math.max(document.documentElement.scrollTop, document.body.scrollTop) - settings.defHeight;
};
var imgLoad = function() {
defObj.each(function() {
if ($(this).offset().top <= pageTop()) {
var src2 = $(this).attr("src2");
//表示されたものは再度表示する必要はありません
if (src2) {
;
}
}
});
};
imgLoad(); );
});
}
lazyload({
defObj:".w1"
});