説明と解決策はMDN にあります。
コールバック関数に引数を渡す必要があるが、(setTimeout() または setInterval() で) 追加パラメーターの送信をサポートしていない Internet Explorer で動作させる必要がある場合は、この IE 固有の互換性コードを含めることができます。スクリプトの先頭に挿入するだけで、両方のタイマーに対してそのブラウザーで HTML5 標準パラメーター通過機能が有効になります。
if (document.all && !window.setTimeout.isPolyfill) {
var __nativeST__ = window.setTimeout;
window.setTimeout = function (vCallback, nDelay /*, argumentToPass1, argumentToPass2, etc. */) {
var aArgs = Array.prototype.slice.call(arguments, 2);
return __nativeST__(vCallback instanceof Function ? function () {
vCallback.apply(null, aArgs);
} : vCallback, nDelay);
};
window.setTimeout.isPolyfill = true;
}
if (document.all && !window.setInterval.isPolyfill) {
var __nativeSI__ = window.setInterval;
window.setInterval = function (vCallback, nDelay /*, argumentToPass1, argumentToPass2, etc. */) {
var aArgs = Array.prototype.slice.call(arguments, 2);
return __nativeSI__(vCallback instanceof Function ? function () {
vCallback.apply(null, aArgs);
} : vCallback, nDelay);
};
window.setInterval.isPolyfill = true;
}