在 JavaScript 中,可以使用 getter 和 setter 方法来实现既可以获取又可以设置属性的类。以下是一个示例:
class ExampleClass {
constructor() {
this._property = 0;
}
get property() {
return this._property;
}
set property(value) {
this._property = value;
}
}
const example = new ExampleClass();
console.log(example.property); // 输出: 0
example.property = 10;
console.log(example.property); // 输出: 10
这种方法是一种常见的做法,可以让你在获取或设置属性时执行一些逻辑。例如,在 getter 中可以对属性进行验证或转换,而在 setter 中可以做一些额外的操作。
然而,有人认为这种方式可能不够好,因为它破坏了面向对象编程中的封装原则。通过直接访问属性而不是使用 getter 和 setter 方法,可以更好地控制属性的访问和修改。此外,使用 getter 和 setter 方法可能会导致代码更加复杂,因为需要在每次访问该属性时都需要调用方法。
因此,这种做法是有争议的,取决于具体的情况和个人的编码风格。在某些情况下,使用 getter 和 setter 方法可能是有价值的,但在其他情况下,直接访问属性可能更合适。