订单状态变为新状态后,如何从一个州转换到另一个州。我在Yii2中实现这一点。
var i = 1;
$('.progress .circle').removeClass().addClass('circle');
$('.progress .bar').removeClass().addClass('bar');
setInterval(function() {
$('.progress .circle:nth-of-type(' + i + ')').addClass('active');
$('.progress .circle:nth-of-type(' + (i-1) + ')').removeClass('active').addClass('done');
$('.progress .circle:nth-of-type(' + (i-1) + ') .label').html('✓');
$('.progress .bar:nth-of-type(' + (i-1) + ')').addClass('active');
$('.progress .bar:nth-of-type(' + (i-2) + ')').removeClass('active').addClass('done');
i++;
if (i==0) {
$('.progress .bar').removeClass().addClass('bar');
$('.progress div.circle').removeClass().addClass('circle');
i = 1;
}
}, 1000);
这是我的JSfiddle http://jsfiddle.net/9cs776m0/1/
答案 0 :(得分:0)
尝试
var circles = $('.progress .circle');
var currentCircle = circles.first();
var previousCircle = $();
(function()
{
currentCircle.addClass('active');
previousCircle.removeClass('active').addClass('done');
var bar = currentCircle.prev();
bar.addClass('done');
previousCircle = currentCircle;
currentCircle = currentCircle.nextAll('.circle:first');
if (previousCircle.length)
{
setTimeout(arguments.callee, 1000);
}
})();
我在条件
上没有额外的课程half