Unable to run BlockUI Asynchronously with other scripts

Unable to run BlockUI Asynchronously with other scripts

I'm a bit of a noob, but I've tried this many ways and have been banging my head against the wall for the past week or so trying to find a solution. 

I've got a search form that when submit is fired, I was hoping to block the browser screen WHILE the other two scripts completed.  With my code below, all three scripts execute, but the blockUI fires LAST for some reason.  

What am I doing wrong?  Is this even possible?

 
HTML:

  1.             <div id="search"  class="Column">
  2.                 <form id="searchForm" method="post" action="" onsubmit="executeAsynchronously([blockUI, highlight, count], 10); return false;">
  3.                     <input name="text-search" id="text-search" type="text"   value=""       class="input"  placeholder="search">
  4.                     <inpu  id="submit" type="submit" value="Submit" class="button"  />
  5.                 </form>
  6.                 <div class="count"></div>
  7.             </div>




JS:

  1. $(document).ajaxStop($.unblockUI);

  2. function executeAsynchronously(functions, timeout) {
  3.   for(var i = 0; i < functions.length; i++) {
  4.     setTimeout(functions[i], timeout);
  5.   }
  6. }

  7. function blockUI() {
  8.     $.blockUI({
  9.         css: {
  10.             'border': 'none',
  11.             'padding': '15px',
  12.             'backgroundColor': '#000000',
  13.             '-webkit-border-radius': '10px',
  14.             '-moz-border-radius': '10px',
  15.             'opacity': '0.8',
  16.             'color': '#EEEBEC',
  17.             'font-size': '32px',
  18.         },
  19.         message: 'Searching...',
  20.         fadeIn: 200,
  21.         fadeOut: 400,
  22.     });
  23. };

  24. function highlight() {
  25.     var text = document.getElementById("text-search").value;
  26.     var query = new RegExp("(\\b" + text + "\\b)", "gim");
  27.     var e = document.getElementById("body").innerHTML;
  28.     var enew = e.replace(/(<span>|<\/span>)/igm, "");
  29.     document.getElementById("body").innerHTML = enew;
  30.     var newe = enew.replace(query, "<span>$1</span>");
  31.     document.getElementById("body").innerHTML = newe;
  32.     color = "#f6f";
  33. };


  34. function count() {
  35.     var count = document.getElementsByClassName("body").length;
  36.     document.getElementsByClassName("count")[0].innerHTML = count;
  37. };