Задать вопрос

Как сделать порядок выполнения и transitionend jQuery?

Добрый день, есть следующий код, в нем происходит добавление класса к дивам ".col-xs-3", как сделать чтобы после того, как сработал each я мог вывести сообщение об успехе, а не после каждой итерации? Заранее спасибо.
$("#btn").click(function () {
    $(this).text('in progress');

    console.log("--Start process--");

    var hold = 500;
    var elems = $(".col-xs-3");
    var count = elems.length;

    elems.each(function (i, t) {
        var $this = $(t);
        setTimeout(function () {
            console.log("Start animation " + $this.text());
            if ($this.hasClass("flip_effect_vertical")) {
                $this.removeClass("flip_effect_vertical");
            } else {
                $this.addClass("flip_effect_vertical");
            }
            $this.on('transitionend webkitTransitionEnd oTransitionEnd', function () {
                console.log("End animation " + $this.text());
            });
        }, i * hold);
        success();
    });

    function success() {
        alert("Success");
        console.log("--End process--");
        $("#btn").text('start');
    }

});
  • Вопрос задан
  • 1228 просмотров
Подписаться 1 Оценить Комментировать
Решения вопроса 1
werty1001
@werty1001
undefined
$("#btn").click(function () {
    $(this).text('in progress');

    console.log("--Start process--");

    var hold = 500;
    var elems = $(".col-xs-3");
    var count = elems.length;

    elems.each(function (i, t) {
        var $this = $(t);
        setTimeout(function () {
            console.log("Start animation " + $this.text());
            if ($this.hasClass("flip_effect_vertical")) {
                $this.removeClass("flip_effect_vertical");
            } else {
                $this.addClass("flip_effect_vertical");
            }
            $this.on('transitionend webkitTransitionEnd oTransitionEnd', function () {
                console.log("End animation " + $this.text());
            });
        }, i * hold);
        if (i === --count) success();
    });

    function success() {
        alert("Success");
        console.log("--End process--");
        $("#btn").text('start');
    }

});
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы