Ext.define("MyClass.A", {
config: {
name: "tom",
sex: "male"
},
show: function(){
// console.log(this.config.name);
alert(this.config.name);
}
});
config属性会将为其属性自动添加setter和getter函数。
若打算修改setter的行为,可以重写“apply属性名”方法,该方法将为setter的内部实现。具体代码如下:
Ext.define("MyClass.A", {
config: {
name: "John Huang",
sex: "male"
},
applyName: function(val){
this.name = "dev: " + val;
},
show: function(){
console.log(this.name);
}
});
调用getName方法时的内部实现步骤如下:
1. 检查对象是否有name属性,有则执行步骤2,无则执行步骤3;
2. 返回name属性,并更新内部实现;
3. 以config.name为参数执行applyName函数,然后更新内部实现。
第N次调用getName方法是的内部实现如下:
function(){ return this[q]; },直接返回对象的属性。
结论:setter和getter是将config的成员属性复制(注意:为浅复制)为当前类的成员属性,然后对成员属性进行后续操作。
因此我们在重写applyName时需要遵守下列原则:要修改config的成员属性值