Safari浏览器在window.location之后停止执行js

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Safari浏览器在window.location之后停止执行js相关的知识,希望对你有一定的参考价值。

我有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秒以上才能完成。

这是什么问题?为什么野生动物园总是糟透了

答案

在找不到合适的解决方案之后,我将我的请求转移到了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);
    }

以上是关于Safari浏览器在window.location之后停止执行js的主要内容,如果未能解决你的问题,请参考以下文章

关于 Safari 浏览器不支持 location [ window.location.href window.open()] 跳转问题的解决方案

window.location 在 Safari 上调用弹出空对话框

移动 Safari:frame.src 与 window.location

一个关于window.location.href=window.location.href的问题?

location属性解释 - window.location & $location

window.location.href 在浏览器里无法跳转