From c159eb729d9dd4fec5611cbc131d6422063562f8 Mon Sep 17 00:00:00 2001 From: jenkey2011 Date: Tue, 22 May 2018 21:22:07 +0800 Subject: [PATCH] fix: infinityscroll bugs for #1149 --- src/mip-infinitescroll/infinitescroll.js | 28 +++++++++++++++++--- src/mip-infinitescroll/mip-infinitescroll.js | 3 ++- 2 files changed, 27 insertions(+), 4 deletions(-) diff --git a/src/mip-infinitescroll/infinitescroll.js b/src/mip-infinitescroll/infinitescroll.js index d99425afe..0256ad84a 100644 --- a/src/mip-infinitescroll/infinitescroll.js +++ b/src/mip-infinitescroll/infinitescroll.js @@ -6,6 +6,7 @@ define(function (require) { // 使用了jquery $.Deferred + var util = require('util'); var $ = require('jquery'); var viewport = require('viewport'); var InfiniteScroll = function (opt) { @@ -16,6 +17,7 @@ define(function (require) { opt.$result = $(opt.$result); opt.$loading = $(opt.$loading); + opt.$ele = opt.ele; // 设置默认值 me.options = $.extend({ @@ -176,8 +178,7 @@ define(function (require) { var scrollHandler; viewport.on('scroll', function scrollHandler () { // 若为暂停状态,什么也不做 - - if (me.state === 'pause') { + if (me.state === 'pause' || !me._isElementInViewport()) { return; } @@ -185,6 +186,8 @@ define(function (require) { me.currentScrollTop = viewport.getScrollTop(); // 某些浏览器(安卓QQ)滚动时会隐藏头部但不触发resize,需要反复获取 wtf... me.wrapperHeight = viewport.getHeight(); + // 获取容器高度 + me.scrollerHeight = viewport.getScrollHeight(); // 到顶了 if (me.currentScrollTop <= 0) { @@ -261,7 +264,7 @@ define(function (require) { // trigger scroll事件,确保继续触发数据加载 viewport.trigger('scroll'); } - // 失败 + // 失败 }, function () { // 标记数据状态为请求失败 me.dataStatus = 3; @@ -376,6 +379,25 @@ define(function (require) { ); }, + /** + * 判断组件是否在可视区域内 + * + * @return {boolean} true 或 false + */ + _isElementInViewport: function () { + var ele = this.options.$ele; + var rect = util.rect.getElementRect(ele); + + var winWidth = viewport.getWidth(); + var winHeight = viewport.getHeight(); + var offRect = util.rect.getElementOffset(ele); + var offLeft = offRect.left; + var offTop = offRect.top; + var offWidth = offRect.width; + var offHeight = offRect.height; + + return (offLeft > -offWidth && offLeft < winWidth && offTop > -offHeight && offTop < winHeight) + }, /** * 获取当前可视区页码的方法(从0计) * diff --git a/src/mip-infinitescroll/mip-infinitescroll.js b/src/mip-infinitescroll/mip-infinitescroll.js index af560767d..af51fe04b 100644 --- a/src/mip-infinitescroll/mip-infinitescroll.js +++ b/src/mip-infinitescroll/mip-infinitescroll.js @@ -125,7 +125,8 @@ define(function (require) { limitShowPn: 0, preLoadPn: 2, firstResult: [], - pushResult: self.pushResult + pushResult: self.pushResult, + ele: element }); };