Вот интересный случай цепочки областей действия, не описанный во многих документах, который мне трудно понять.Если кто-то может найти время, чтобы прочитать хорошо прокомментированный код ниже и объяснить, как переменная разрешается, было бы очень хорошо
У меня есть два прямоугольника (DIV) на документе.Я регистрирую прослушиватели событий для mousedown на обоих, а внутри прослушивателя mousedown я регистрирую mouseup.Странная вещь происходит в слушателе mouseup.
Два контекста выполнения создаются путем двойного вызова testfunc с разными значениями аргументов:
window.onload = function() {
test_func("horizontal"); // First Execution context
test_func("vertical"); // Second Execution Context
}
В слушателе mouseup первого прямоугольника (горизонтальный) используется второй контекст выполнения (вертикальный), который противоречит интуиции:
function test_func(dir) {
var X = 9; // variable which helps to track the execution contexts
if(dir === "horizontal")
X = 1; // leave at 9 if vertical
mouseup_vert = function() {}
mouseup_horiz = function() {
// Here the value of X I am getting is 9 whereas I am expecting 11
// QUESTION: Why I am getting the second execution context??
}
mousedown_vert = function() {
// As expected the value of X here is 9
X=99;
// set X to 99 to check if during mouseup same exec context is picked
document.addEventListener("mouseup", mouseup_vert, false);
}
mousedown_horiz = function() {
// As expected value of X is 1, so using first execution context
X=11;
// set this to check if during mouseup I get a value of 11
document.addEventListener("mouseup", mouseup_horiz, false);
}
if (dir === "horizontal") {
e = document.getElementById("horiz");
e.addEventListener("mousedown", mousedown_horiz, false);
} else {
e = document.getElementById("vert");
e.addEventListener("mousedown", mousedown_vert, false);
}
}