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

首先描述一下功能##

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

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

然后说一下bug##

  1. 首次加载时图片可以获取成功,
  2. 再次加载失败,通过chrome调试发现img 的 data-lazyload 属性没改变
  3. 调试的时候发现了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;
		}
  1. 问题找到了,那么就在再次加载数据时,清除该属性就ok了
  document.body.removeAttribute('data-imagelazyload');
		mui(document).imageLazyload({
			placeholder: '../../images/img_head3.png'
		});

END##

那么问题来了:

为什么会这么考虑,还有其他的解决方案么?

最新的解决方案参考DCloud问答的官方回复

posted @ 2015-06-04 17:34  小云菜  阅读(4322)  评论(0编辑  收藏  举报