gpt4 book ai didi

javascript - 在对象的属性中使用 'set' 的好处?

转载 作者:行者123 更新时间:2023-11-30 20:27:42 24 4
gpt4 key购买 nike

我正在学习 Codecademy 类(class)并编写了以下有效代码:

let person = {
_name: 'Lu Xun',
_age: 137,

set age (newAge) {
if (typeof newAge === 'number'){
this._age= newAge;
} else {
console.log('Invalid input');
}
}
}

person.age= 22;

console.log(person['_age']);

我开始思考集合的工作原理,并认为它的工作原理与在 person 对象中定义方法的工作原理基本相同,只是语法不同而已。

所以我试了一下,调用了 age 方法,使用调用方法的正常方式从对象外部将 22 传递给它。效果一样。见下文。

let person = {
_name: 'Lu Xun',
_age: 137,

age: function (newAge) {
if (typeof newAge === 'number'){
this._age= newAge;
} else {
console.log('Invalid input');
}
}
}

person.age(22);

console.log(person['_age']);

使用“set”语法有什么好处?即,当正常的函数/方法定义以相同的方式工作时,为什么要使用它?

最佳答案

想象一下,您编写了一段非常庞大的代码,其中很多代码都像这样访问一个变量:

// The object
const person = { age: 12 }
// You access it very often
console.log(person.age);

现在你当然想根据生日计算年龄。使用方法时,每次使用它时都必须将 person.age 替换为 person.getAge()。这可能需要时间。使用 getters/setters,你可以只替换一行,一切都会继续工作。

如果您认为这不是问题,您可能想看看 this java thread . Java 没有 getters/setters。

关于javascript - 在对象的属性中使用 'set' 的好处?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50704188/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com