Search code examples
javascriptajaxprofilingsingle-page-applicationnavigation-timing-api

Can I use the browser Navigation Timing API for Ajax events in single page apps? If not, what's a good tool?


We've got a single page app built with Knockout and Backbone which makes Ajax calls to the server and does some complex data caching and DOM rendering. We're really like to measure the performance (and log it back to the server) as seen by the user. I can't seem to get my head wrapped around whether the browser Navigation Timing API is going to be useful for this or not. From what I see in examples, the Navigation Timing API is tied to window.performance and this is limited to the page load and not suitable for monitoring Ajax behavior. True or false? If false, what else can I use?

I'd love to set custom instrumentation points between which to measure time, e.g. for an Ajax call that does some DOM rendering with a server result.


Solution

  • 1 - True, window.performance is tied to page load. See example below which shows this:

        <button id='searchButton'>Look up Cities</button>
        <br>
        Timing info is same? <span id='results'></span>
        <script type="text/javascript" src="//code.jquery.com/jquery-1.9.1.min.js"></script>
        <script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/underscore.js/1.4.4/underscore-min.js"></script>
        <script type="text/javascript">
            jQuery('#searchButton').on('click', function(e){
                // deep copy the timing info
                var perf1 = jQuery.extend(true, {}, performance.timing);             
                // do something async
                jQuery.getJSON('http://ws.geonames.org/searchJSON?featureClass=P&style=full&maxRows=10&name_startsWith=Denv', function() {
                    // get another copy of timing info
                    var perf2 = jQuery.extend(true, {}, performance.timing);
                    // show if timing information has changed
                    jQuery('#results').text( _.isEqual( perf1, perf2 ) );
                });
                return false;
            });
        </script>
    

    Also, even if you did get it working you'd have missing data from old browsers that don't support this object.

    2 - The Boomerang project seems to go beyond the web timing API and also supports older browsers. There is a talk with slides and sample code by the current maintainer listed in this conference. Sorry no direct link.