当最后一张照片出现在屏幕上时,如何让div“con”停止?
意思是当我看到右边的最后一张图片时,我希望动画停止工作
谢谢
http://codepen.io/anon/pen/LVLWRg
HTML
<div class="con">
<div class="conSingle">
<img src="http://i.imgur.com/cjgKmvp.jpg">
</div>
<div class="conSingle">
<img src="http://i.imgur.com/cjgKmvp.jpg">
</div>
<div class="conSingle">
<img src="http://i.imgur.com/cjgKmvp.jpg">
</div>
<div class="conSingle">
<img src="http://i.imgur.com/cjgKmvp.jpg">
</div>
<div class="conSingle">
<img src="http://i.imgur.com/cjgKmvp.jpg">
</div>
</div>
JS
$(document).ready(function() {
$(".con").click(function() {
$(this).animate({right:"+=100"},1000);
});
});
答案 0 :(得分:1)
这应该适合你:
$(document).ready(function() {
var last = $(".conSingle:last"), offsetRight;
$(".con").click(function() {
if(!$(this).is(":animated")){
offsetRight = $(window).width() - (last.offset().left + last.width());
if(offsetRight !== 0){
if(offsetRight + 100 < 0){
$(this).animate({left:"-=100"},500);
}else{
$(this).animate({left:"-="+(-offsetRight)},500);
}
}
}
});
$('button').click(function(){
if(!$(".con").is(":animated")){
$(".con").animate({left:"0"},500);
}
});
});
检查offset right
元素的.con
,当此offset
高于0
时,请停止动画。