views:

31

answers:

1

I have code that relies on jquery that works here:

    $(function() {  


 var referrer = document.referrer;
    var dataText = 'client='+client+'&referrer=';
   dataText = dataText + referrer;

    // Create the AJAX request  
    $.ajax({  
        type: "GET",                   
        url: "http://www.myurl.com/project/thecollector.php",            
        data: dataText,                  
        success: function() {            
            $('#complete').html( 'Your page view has been added!' );  
        }  
    });  
});

I have rewritten the code to not need jquery here:

window.addEventListener('domready', function()
{
 var referrer = document.referrer; 
    var dataText = 'client='+client+'&referrer=';  
   dataText = dataText + referrer;

 if (window.XMLHttpRequest)        
 {
  // code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp = new XMLHttpRequest();       
 }
 else        
 {
  // code for IE6, IE5
  xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");        
 }
 var url = "http://www.myurl.com/project/thecollector.php?"+dataText;        
 xmlhttp.open("GET",url,false);        
 xmlhttp.send(null);       
});

The problem I am having is that the jquery code always captures the information to the server I am looking for, but the latter only captures it every once and a while, and it feel seemingly random. Is there any way to have a function call to force it, and I tried onload and it doesn't work either.

+1  A: 

"domready" is not an event, so I'm surprised this works at all. For instance, in Mozilla and Opera it should be DOMContentLoaded. Are you sure it's not working just because sometimes document.referrer is empty and sometimes it is not?

It would be so much simpler if you just put the code in a <script> block (preferably in an external file) and put it just before the closing tag. Then it would run when the DOM is ready, and there's no faffing about with events. That ought to work fine.

Finally, this looks like it would be best done on the server side, as with something like PHP you can also access the HTTP referrer. Then you can just output the result straight into the HTML. Plus you allow that odd user out there using NoScript or just browsing without JavaScript to see this content.

Rafael
Sorry I didn't include all of the code, but this actually is dynamically inserted onto the webpage, and is hosted on the server side. It inserts the code into the head section of the page, but the original js that inserts it is sitting right above the close body tag. I also tried window.onload = function() to no avail.
Then you shouldn't be inserting it into the head. Why not just insert it into the body? Also, if you're inserting it in the head _after_ the DOM has loaded, then you don't need to add any listeners to wait for the DOM to load - it's loaded already!
Rafael