How to prevent “Stop running this Script” in browsers?

后端 未结 3 1529
闹比i
闹比i 2021-02-15 12:49

I have an ASP.NET MVC page that has JQuery Editable Datatable that has 14 columns. I have a button (Apply No Findings)to do Client side calcultions snd apply for all Rows in tha

3条回答
  •  有刺的猬
    2021-02-15 13:23

    The problem is javascript is single-threaded, so if there is a function that takes too long to complete, this function could cause the UI not responding. Therefore, the browser will warn the user about long running script by displaying the message: "Stop running this script". The solutions to this problem are:

    • Optimize your code so the function does not take so long.
    • Use setTimeout to break the function execution into many pieces that are short enough.

    Example code pattern:

    var array = []; //assume that this is a very big array
    var divideInto = 4;
    var chunkSize = rowCount/divideInto;
    var iteration = 0;
    
    setTimeout(function doStuff(){
      var base = chunkSize * iteration;
      var To = Math.min(base+chunkSize,array.length);
      while (base < To ){
          //process array[base]
          base++;
      }
      iteration++;
      if (iteration < divideInto)
          setTimeout(doStuff,0); //schedule for next phase
    },0);
    

    The solution you take in your Example(2) is correct, but there is a problem in your code. That's the setTimeout does not run. Try changing your code like this:

    RepeatingOperation = function(op, yieldEveryIteration) 
      {  
      var count = 0;  
      var instance = this;  
      this.step = function(args) 
        {    
           op(args); 
           if (++count <= yieldEveryIteration) 
           {          
             setTimeout(function() { instance.step(args); }, 1, [])         
           }    
        };   
      };
    

    Modify your function ApplyNoFindings(), try this:

    if (++i > iTotalRecords) 
     { 
        UpdateSummaryLine();
        UpdateSummaryLineReasonCode();
     }  
    

    instead of:

    if (++i < iTotalRecords) 
         { 
            ro.step(); 
         }  
         else 
         { 
            UpdateSummaryLine();
            UpdateSummaryLineReasonCode();
         }  
    

    Note: not tested, just give you an idea how it should work

提交回复
热议问题