您的位置:首页 > 产品设计 > UI/UE

MUI - 解决动态列表页图片懒加载再次加载不成功的bug

2015-06-04 17:34 477 查看

首先描述一下功能

实现列表页动态加载

通过官方提供的"下拉刷新和上拉刷新"及"图片懒加载"示例实现。

http://www.cnblogs.com/phillyx/

然后说一下bug

首次加载时图片可以获取成功,

再次加载失败,通过chrome调试发现img 的 data-lazyload 属性没改变

调试的时候发现了bug

$.fn.imageLazyload = function(options) {
var lazyloadApis = [];
this.each(function() {
var self = this;
var lazyloadApi = null;
if (self === document || self === window) {
self = document.body;
}
//对,bug就在这,判定时如果body已有该属性,就不在加载了,整体的代码没看明白,注释太少了啊
var id = self.getAttribute('data-imageLazyload');
if (!id) {
id = ++$.uuid;
$.data[id] = lazyloadApi = new ImageLazyload(self, options);
self.setAttribute('data-imageLazyload', id);
} else {
lazyloadApi = $.data[id];
}
lazyloadApis.push(lazyloadApi);
});
return lazyloadApis.length === 1 ? lazyloadApis[0] : lazyloadApis;
}


问题找到了,那么就在再次加载数据时,清除该属性就ok了

document.body.removeAttribute('data-imagelazyload');
mui(document).imageLazyload({
placeholder: '../../images/img_head3.png'
});


END

那么问题来了:

为什么会这么考虑,还有其他的解决方案么?
最新的解决方案参考DCloud问答的官方回复
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: