我的代码存在一些问题。我希望括号在用户滚动屏幕上可见时动画。我的问题是页面上的所有h2元素在屏幕上显示时同时生成动画。下面是使用的jQuery,这里是jsfiddle的链接:
提前致谢, 麦克
$(window).scroll( function(){
var test1 = $('article h2 span.bracket1');
var bottom_of_object1 = $(test1).position().top + $(test1).outerHeight();
var bottom_of_window = $(window).scrollTop() + $(window).height();
if( bottom_of_window > bottom_of_object1 ){
$(test1).addClass( "slideLeft" );
setTimeout(function() {
$("article h2 .spanContent").animate({'opacity':'1'},1000);
}, 1000);
};
var test2 = $('article h2 span.bracket2');
var bottom_of_object2 = $(test2).position().top + $(test2).outerHeight();
if( bottom_of_window > bottom_of_object2 ){
$(test2).addClass( "slideRight" );
};
var test3 = $('article h2 span.bracket3');
var bottom_of_object3 = $(test3).position().top + $(test3).outerHeight();
if( bottom_of_window > bottom_of_object3 ){
$(test3).addClass( "slideLeft" );
setTimeout(function() {
$("article h2 .spanContent2").animate({'opacity':'1'},1000);
}, 1000);
}
var test4 = $('article h2 span.bracket4');
var bottom_of_object4 = $(test4).position().top + $(test4).outerHeight();
if( bottom_of_window > bottom_of_object4 ){
$(test4).addClass( "slideRight" );
}
});
每个陈述:
$('.featureImages img, article p, article ul li').each( function(i){
var bottom_of_object = $(this).position().top + $(this).outerHeight();
var bottom_of_window = $(window).scrollTop() + $(window).height();
if( bottom_of_window > bottom_of_object ){
$(this).animate({'opacity':'1'},1000);
}
});
答案 0 :(得分:1)
您是否尝试过使用offset()
代替position()
?
var offset = $(test1).offset();
var bottom_of_object1 = offset.top + $(test1).outerHeight();