我想计算访问者在某个页面上花费的时间并将其存储在我的 MySQL 数据库中。
我想像这样在 window.onload 上启动一个计时器:
window.onload= startCount;
window.onunload= sendCount;
var b=0;
var y;
function startCount() {
document.getElementById('livecount').innerHTML=b;
b=b+1;
y=setTimeout("startCount()",1000);
}
在访问者离开页面(window.onunload)后,我通过 XMLHttpRequest 将时间发送到 PHP 文件,该文件将其存储在我的数据库中:
function sendCount() {
clearTimeout(y);
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","count.php?q="+b,true);
xmlhttp.send();
}
问题是它并不总是有效。我会说它的效果就像我尝试它的 10 次中的 3 次一样。难道是没有足够的时间让PHP和SQL完全执行?