Сеттеры/геттеры Javascript
-
19-09-2019 - |
Вопрос
var author = {
firstname: 'Martin',
lastname: 'Hansen'
}
function settersGetters(propStr) {
for (var i = 0; i < propStr.length; i++) {
author['_'+ propStr[i]] = null;
author.__defineGetter__(propStr[i],
function() {
return author['_'+ propStr[i]];
});
author.__defineSetter__(propStr[i],
function(val) {
author['_'+ propStr[i]] = val;
});
};
}
Мы надеемся, что приведенный выше код будет генерировать методы установки/получания для любых предоставленных свойств (в массиве) для автора объекта.
Но когда я вызываю приведенный ниже код, и имя, и фамилия — Олсен..Что я делаю не так?
settersGetters(['firstname', 'lastname']);
author.firstname = 'per';
author.lastname = 'olsen';
console.log(author.firstname);
console.log(author.lastname);
Решение
Определение делается в замыкании, поэтому все установщики используют последнее значение i.
Вместо этого используйте это:
function setterGetter(property)
{
author['_'+ property] = null;
author.__defineGetter__(property,
function() {
return author['_'+ property];
});
author.__defineSetter__(property,
function(val) {
author['_'+ property] = val;
});
}
function settersGetters(propStr) {
for (var i = 0; i < propStr.length; i++) {
setterGetter(propStr[i]);
};
}
Другие советы
Я подозреваю, что это проблема закрытия, которую мне объяснили несколько полезных людей. здесь.
Попробуйте обернуть i
ссылку внутри функции и прочитайте о замыканиях.Несмотря на всю помощь, признаюсь, я до сих пор их не очень понимаю.
Не связан с StackOverflow