首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >jQuery循环,添加和删除类

jQuery循环,添加和删除类
EN

Stack Overflow用户
提问于 2013-08-09 15:09:14
回答 1查看 1.6K关注 0票数 1

嗨,我有一个叫setTimeout的函数,函数如下

代码语言:javascript
复制
function slideuptwitter(){

    for (var i = 0, limit = 10; i < limit; i++) {
            $('.twitter-article').first().addClass('fade');
            $('.fade').delay( 2000 ).slideUp(5000);
            //$('.fade').appendTo('#twitter-feed');

            //$('.fade').delay( 5000 ).removeClass('fade');

            }

    }

这是我的版面

代码语言:javascript
复制
<div id="twitter-feed">
<div class="twitter-article">
<div class="twitter-article">
<div class="twitter-article">
<div class="twitter-article">
<div class="twitter-article">
<div class="twitter-article">
<div class="twitter-article">
<div class="twitter-article">
<div class="twitter-article">
</div>

我想抓住第一篇推特文章,添加类淡出,然后在2秒后,滑动它。

在此之后,我想将淡出类移到底部,删除类并将类重新应用到twitter文章中的下一个。

从本质上讲贯穿了所有的10个

注释掉的代码是为我工作的部分。

谢谢你的帮助

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-08-09 15:13:47

使用异步递归:http://jsfiddle.net/7TQCr/2/

代码语言:javascript
复制
function fadeOut(elements, callback)
{
    if (elements.length){
        elements.eq(0).addClass('fade');
        elements.eq(0).delay( 2000 ).slideUp(1000, function(){
            elements.eq(0).removeClass('fade');
            fadeOut(elements.slice(1), callback);
        });
    }
    else {
        callback();
    }
}
$(function(){
    fadeOut($('#twitter-feed div'), function(){
        alert("done");
    });
});

更新以执行特定的淡入和类要求。

无限fadeout/fadein版本http://jsfiddle.net/7TQCr/4/

代码语言:javascript
复制
function fadeOut(elements, callback)
{
    if (elements.length){
        elements.eq(0).addClass('fade');
        elements.eq(0).delay( 2000 ).slideUp(1000, function(){
            elements.eq(0).removeClass('fade');
            fadeOut(elements.slice(1), callback);
        });
    }
    else {
        callback();
    }
}
function fadeIn(elements, callback)
{
    if (elements.length){
        elements.eq(0).addClass('fade');
        elements.eq(0).delay( 2000 ).slideDown(1000, function(){
            elements.eq(0).removeClass('fade');
            fadeIn(elements.slice(1), callback);
        });
    }
    else {
        callback();
    }
}
function infinite(){
    fadeOut($('#twitter-feed div'), function(){ 
        fadeIn($('#twitter-feed div'), function(){
            infinite();
        });
    });
}
$(function(){
    infinite();
});
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18149948

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档