作者:冰冻的幸福yasminzp_815 | 来源:互联网 | 2020-09-03 11:16
JavaScript访问器(Getter和Setter),ECMAScript5(2009)介绍了Getter和Setters。Getters和setter允许您定义对象访问器(ComputedProperties)。
Javascript访问器(Getter和Setter),ECMAScript 5(2009)介绍了Getter和Setters。 Getters和setter允许您定义对象访问器(Computed Properties)。
【相关课程推荐:Javascript视频教程】
Javascript Getter(get关键字)
Javascript Getters和Setters
Getters和setter允许您通过方法获取和设置属性。
此示例使用lang属性获取语言属性的值。
Javascript Setter (set关键字)
Javascript Getters和Setters
Getters和setter允许您通过方法获取和设置属性。
此示例使用lang属性设置语言属性的值。
使用Javascript函数还是Getter?
这两个例子之间有什么区别?
示例1:
var person = {
firstName: "John",
lastName : "Doe",
fullName : function() {
return this.firstName + " " + this.lastName;
}
};
// 使用方法显示对象的数据:
document.getElementById("demo").innerHTML = person.fullName();
示例2:
var person = {
firstName: "John",
lastName : "Doe",
get fullName() {
return this.firstName + " " + this.lastName;
}
};
// 使用getter显示来自对象的数据:
document.getElementById("demo").innerHTML = person.fullName;
示例1将fullName作为函数访问:person.fullName()。示例2将fullName作为属性访问:person.fullName。第二个示例提供了更简单的语法。
数据质量
使用getter和setter时,Javascript可以确保更好的数据质量。lang在此示例中,使用属性language以大写形式返回属性的值:
// 创建一个对象:
var person = {
firstName: "John",
lastName : "Doe",
language : "en",
get lang() {
return this.language.toUpperCase();
}
};
// 使用getter显示来自对象的数据:
document.getElementById("demo").innerHTML = person.lang;
lang在此示例中,使用该属性将大写值存储在language属性中:
var person = {
firstName: "John",
lastName : "Doe",
language : "",
set lang(lang) {
this.language = lang.toUpperCase();
}
};
// 使用setter设置对象属性:
person.lang = "en";
// 显示来自对象的数据:
document.getElementById("demo").innerHTML = person.language;
为什么使用Getter和Setter?
● 它提供了更简单的语法
● 它允许属性和方法的语法相同
● 它可以确保更好的数据质量
● 在幕后做事情很有用
Javascript Getters和Setters
完美的创建反对象:
Object.defineProperty()
Object.defineProperty()方法还可用于添加Getters和Setter:
// 定义对象
var obj = {counter : 0};
// 定义 setters
Object.defineProperty(obj, "reset", {
get : function () {this.counter = 0;}
});
Object.defineProperty(obj, "increment", {
get : function () {this.counter++;}
});
Object.defineProperty(obj, "decrement", {
get : function () {this.counter--;}
});
Object.defineProperty(obj, "add", {
set : function (value) {this.counter += value;}
});
Object.defineProperty(obj, "subtract", {
set : function (value) {this.counter -= value;}
});
// Play with the counter:
obj.reset;
obj.add = 5;
obj.subtract = 1;
obj.increment;
obj.decrement;
浏览器支持
Internet Explorer 8或更早版本不支持Getters和Setter:
Internet Explorer | Chrome | FireFox | Safari | Opera |
---|
|
9.0+ | 支持 | 支持 | 支持 | 支持 |
本文来自 js教程 栏目,欢迎学习!
以上就是深入学习Javascript对象访问器(Getter和Setter)的详细内容,更多请关注 第一PHP社区 其它相关文章!