我有js代码,按钮点击显示(假)进度条。 比设定超时时更改进度条的值
$(".quickbook-btn").click(function(){
$(".progress").removeClass('hide')
setTimeout(barAnim, 50);
window.location = path
});
var value = 0;
function barAnim(){
value += 5;
$( ".progress-bar" ).css( "width", value + "%" ).attr( "aria-valuenow", value );
$(".progress-bar").text((value)+'%');
if ( value == 10 || value == 20 || value == 30|| value == 50 || value == 75 || value == 90 ) {
return setTimeout(barAnim, 1500);
}
}
它在chrome,Firefox等中完美运行。
但是当涉及到Safari时,它会在到达window.location行时停止js执行。
我甚至测试过它,让进度达到50%并且比调用window.location立即停止执行js,尽管window.location中的url需要10秒以上才能完成。
这是什么问题?为什么safari总是糟透了
答案 0 :(得分:0)
在找不到合适的解决方案后,我将我的请求转移到了ajax&响应使用window.location。 (但有一点可以肯定Safari很糟糕)
$(".quickbook-btn").click(function(){
$(".progress").removeClass('hide')
setTimeout(barAnim, 50);
$.ajax({
method: "GET",
url: "#{path}",
}).done(function( data ) {
$( ".progress-bar" ).css( "width", 100 + "%" ).attr( "aria-valuenow", 100 );
$(".progress-bar").text((100)+'%');
window.location = "#{club_quick_books_path}"
});
});
var value = 0;
function barAnim(){
value += 5;
$( ".progress-bar" ).css( "width", value + "%" ).attr( "aria-valuenow", value );
$(".progress-bar").text((value)+'%');
if ( value == 10 || value == 20 || value == 30|| value == 50 || value == 75 || value == 90 ) {
return setTimeout(barAnim, 1500);
}
return value >= 95 || setTimeout(barAnim, 50);
}