2011-06-10 9 views
0

このページでは、いくつかのフィルタ条件を設定して、フィルタボタンをクリックすると、データが取得されます。Firefoxでの奇妙なjQueryのパフォーマンスの問題を解決する

これはすごくうまくいきます。それはうまく戻ってきて、文書の中に入れて、新しいコンテンツに適用されるすべてのホバーとクリックの機能は、大丈夫、素早く素早く反応します。

一度大きなページがあると、フィルタボタンはクリックに反応するのに4〜5秒かかります。

IE 9では、IEの古いバージョンでは、他のものは9より遅くなりますが、予想される/許容可能な速度です。

私はいくつかのプロファイリングなどを行っています。興味深いのは、ボタンがクリックされてから4-5秒後まで、関数の最初のところにconsole.logステートメントが記録されるということです。もっと面白い、私は最初の行として警告を入れれば、それは即座に発火する!後でクリックハンドラにアラートを入れると、アラートが発生する前のすべてが即座に発生しますが、その後のすべてが遅延します。それがクリックされていますことを認識することがdecideds一度

はずっと、ハンドラで起こっているしないように、それは超高速です:

$('#FilterScheduledShifts').click(function() { 

     console.log("Filter Start:" + new Date().getTime()); 

     var categoryId = $('#FilterCategoryId').val(); 
     var activityId = $('#FilterActivityId').val(); 
     console.log("Before GetShiftStatusFilters:" + new Date().getTime()); 
     var shiftStatusFilters = v2GetShiftStatusFilterIds(); 
     console.log("After GetShiftStatusFilters:" + new Date().getTime()); 
     var dayOfWeekFilters = v2GetDayOfWeekFilters(); 
     console.log("After v2GetDayOfWeekFilters:" + new Date().getTime()); 
     var startDateFilter = v2GetStartDateFilter(); 
     console.log("After v2GetStartDateFilter:" + new Date().getTime()); 
     var endDateFilter = v2GetStartEndFilter(); 
     console.log("After v2GetStartEndFilter:" + new Date().getTime()); 

     if (Date.parse(startDateFilter).isBeforeOrEqual(Date.parse(endDateFilter))) { 
      console.log("inside if statement:" + new Date().getTime()); 

      var dataToPost = { categoryId: categoryId, activityId: activityId, statuses: shiftStatusFilters, daysOfWeek: dayOfWeekFilters, startDate: startDateFilter, endDate: endDateFilter }; 
      var url = $('#UrlToFilter').val(); 

      $('#holder').empty().html($('#LoadingScreen').clone()); 
      console.log("after emptyand loadingscreen:" + new Date().getTime()); 
      $.ajax({ 
       url: url, 
       data: dataToPost, 
       type: 'POST', 
       success: function (data) { 
       console.log("success:" + new Date().getTime()); 
        document.getElementById('holder').innerHTML = data; 
        v2WireUpGetUsersForAllShiftsArrow(); 
        v2SetUpGetShiftUserArrow($('#holder').find('div.GetShiftUserArrow')); 
        v2SetUpGetDayShiftsUsers($('#holder').find('div.GetDayUserArrow')); 
        v2SetUpAssingVolunteersLinks($('#holder')); 
       }, 
       error: function() { 
        v2ErrorNotice(v2Text.shared.genericAjaxErrorMessage); 
       } 

      }); 
     } 
     else { 
      v2ErrorNotice('error'); 
     } 
    }); 

    v2SetUpGetShiftUserArrow($('#holder').find('div.GetShiftUserArrow')); 
    v2SetUpGetDayShiftsUsers($('#holder').find('div.GetDayUserArrow')); 

}); 

これらすべてのconsole.logsは、互いの30または40ミリ秒以内に表示されます。だから私はそこには遅いものはないと知っています。

その他の情報:

span.someClass(私は3だと思う)に割り当てられているページ上のカップルのライブのハンドラがあります。以前はもっと長いことがありましたが、私はそれらを修正しました。この問題に大きな違いはありませんでした(一般的にページは良くなっています)。

jqueryはバージョン1.4.1です(いいえ、私は新しいバージョンにアップグレードできません)。

+0

ファーンバグが開いている場合、特にHTMLタブが開いている場合は、DOMを操作したり読み込んだりすると、パフォーマンスが大幅に低下することがあります。ファイヤーバグを閉じて、役立つかどうか確認してください。 – DanielB

+0

興味深い!火かき棒が閉じていると、遅延は約3秒です。まだそこにあるが、少ない。 – Patricia

+0

@Patricia - クリック機能の外で照会できるセレクタがあるので、一度に多くの機能を実行していませんか?また、 '.html()'を置き換える場合は、 '.empty()'を実行する必要はありません。これは大きなパーセンテージです。 – buzzedword

答えて

2

私が気付いたのは、Firebugが開いている場合、特にHTMLタブの場合、DOMの操作や読み込み中に大きなパフォーマンス低下が生じることがあります。ファイヤーバグを閉じて、パフォーマンスが向上するかどうかを確認します。