我为广告制作了“加载更多”功能
在Chrome和FireFox中没有任何问题,当我尝试在IE(版本10)中选择时,会显示以下JavaScript错误: “无法获取未定义或空引用的属性'偏移'” 我想我已经在Object以外的类型的对象上调用了一个方法或属性,或者在需要Object时传递了一个非Object类型的参数。 所以我尝试下面没有帮助的代码:
function findElementTotalOffset(obj) {
var oleft = otop = 0;
if (obj.offsetParent) {
do {
oleft += obj.offsetLeft;
otop += obj.offsetTop;
} while (obj = obj.offsetParent);
}
return {left : oleft, top : otop};
}
非常感谢任何帮助: - )
import $ from "jquery"
class LazyLoadAds {
constructor() {
this.initLazyLoad = this.initLazyLoad.bind(this)
this.initLazyLoad()
}
initLazyLoad() {
let self = this,
listener = self.throttle(300, function () {
slotsAtlantic.forEach(function (item) {
let $item = $('#' + item.id)
if ($item.length) {
let $parent = $item.parent(),
index = slotsAtlantic.indexOf(item)
if ($parent.is(':visible') && ((window.scrollY || window.pageYOffset) >= ($parent.offset().top - $(window).height() - 300))) {
googletag.cmd.push(function () {
googletag.pubads().refresh([item.slot]);
});
slotsAtlantic.splice(index, 1);
}
}
});
});
window.addEventListener('scroll', listener)
}
throttle(delay, callback) {
var previousCall = new Date().getTime();
return function () {
var time = new Date().getTime();
if ((time - previousCall) >= delay) {
previousCall = time;
callback.apply(null, arguments);
}
};
}
}
export default LazyLoadAds
答案 0 :(得分:0)
看来你得到一个没有父元素的元素。
所以当你写:let $parent = $item.parent()
时,$ parent为空。
如果您想获得$parent.offset()
,则会启动例外。
您是否尝试记录您获得的每个元素?