在 JavaScript 中,我们可以给原型对象添加可选参数。为此,我们需要使用属性存取器(getter 和 setter)代替原型上的方法。下面是示例代码:
// 原型上的方法
function Person(name, age) {
this.name = name;
this.age = age;
}
Person.prototype.sayHello = function() {
console.log('Hello, my name is ' + this.name + '. I am ' + this.age + ' years old.');
};
// 添加可选参数的示例
function Person(name, age) {
this._name = name;
this._age = age;
}
Object.defineProperty(Person.prototype, 'name', {
get: function() {
return this._name;
},
set: function(value) {
this._name = value;
}
});
Object.defineProperty(Person.prototype, 'age', {
get: function() {
return this._age;
},
set: function(value) {
this._age = value;
}
});
Person.prototype.sayHello = function() {
console.log('Hello, my name is ' + this.name + '. I am ' + this.age + ' years old.');
};
在上面的示例中,我们定义了一个 Person
构造函数。在构造函数中,我们使用了属性存取器(getter 和 setter)来存储 name
和 age
属性。然后,我们为 Person
原型对象添加了一个 sayHello
方法来打印出一句问候语。
现在,我们可以创建一个 Person
实例,并向其添加可选参数,如下所示:
var person = new Person('Alice', 30);
person.name = 'Bob';
person.age = 40;
person.sayHello(); // 输出:Hello, my name is Bob. I am 40 years old.
在上面的示例中,我们创建了一个名为 person
的 Person
实例,并将 name
和 age
属性的值设置为 'Bob'
和 `