リンクされた投稿に対する私のコメントへの返信を読んだ後、window
オブジェクトとグローバル スコープに関してテストすることにしました。this、this、thisなどの元の関数を参照する方法に関する他の質問をいくつか読みましたが、通常、それらはすべて、元の関数を別の変数に格納するか、匿名関数 (別の名前空間) にラップすることを伴います。
テストコード
var x = ' 0 '; // a global variable
document.body.innerHTML += x;
document.body.innerHTML += window.x;
// setTimeout before overriding
setTimeout(function () {
document.body.innerHTML += ' 1 ';
}, 500);
// window.setTimeout before overriding
window.setTimeout(function() {
document.body.innerHTML += ' 2 ';
}, 1000);
// Overriding setTimeout
function setTimeout(f, time) {
'use strict';
if (typeof f === 'function') {
document.body.innerHTML += ' 3 ';
}
}
// setTimeout after overriding
setTimeout(function () {
document.body.innerHTML += ' 4 ';
}, 1000);
// window.setTimeout after overriding setTimeout globally
window.setTimeout(function () {
document.body.innerHTML += ' 5 ';
}, 2000);
// Overriding window.setTimeout
window.setTimeout = function (f, time) {
'use strict';
if (typeof f === 'function') {
document.body.style.backgroundColor = 'orange';
}
};
// window.setTimeout after overriding
window.setTimeout(function () {
document.body.innerHTML += ' 6 ';
}, 3000);
jsFiddleを参照してください。フィドルが初期化された後、[実行] をクリックして遅延を確認する必要がある場合があることに注意してください。
実験結果
0
undefined
3
3
(page becomes orange)
2 (after a delay)
5 (after a longer delay)
期待される結果
0
0
3
(page becomes orange)
1 (after 500ms)
2 (after 1000ms)
5 (after 2000ms)
私のコードの動作が予想と異なる理由を誰か説明できますか?
また、ブラウザー環境の外で実行される JavaScript は異なることを認識しているため、この質問の目的のために、ブラウザー環境内の JavaScript のアプリケーションに固執します。