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

首先描述一下功能

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

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

而后说一下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

那么问题来了:chrome

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

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

相关文章
相关标签/搜索