This article tests Firefox, Safari, and Opera and plots performance graphs:
Firefox 2, Opera, and Safari all have a bottom window of 10ms for delays
For older browsers, you can do a test like the one in that article. I just ran a test that I had from a while ago of
setInterval using a 10ms interval in IE6, and I got an average of 55ms.
setTimeout seems to be lower at 35ms.
I ran the test in Chromium and got ~11ms average for a 10ms timeout. I tried it with 4ms and 1ms intervals and got ~4.5ms for both. Also, keep in mind that the numbers could vary among operating systems.
If you're interested, here's the test code:
// number of times to call setTimeout before calculating average
var ITERATIONS = 200;
window.onload = function()
testTimeout(10, +new Date, 0, 0);
// calls setTimeout repeatedly at a specified interval, tracking the amount
// of time that passes between successive calls
function testTimeout(interval, last, sum, ii)
var time = +new Date;
var difference = time - last;
sum += difference;
if (ii % ITERATIONS == 1)
document.body.innerHTML = sum / ITERATIONS;
sum = 0;
testTimeout(interval, time, sum, ii + 1)