5、JavaScript高级之私有属性
2015-03-01 15:41
232 查看
学过java或者C++都知道,给对象声明一个私有属性使用private关键字就可以实现,但是在JavaScript中可不可以声明一个私有属性,答案肯定是可以的,你就相当于写了一句废话吧o(╯□╰)o。
在实现JavaScript的私有属性之前,先来看看一道百度的面试题:
实现一个对象,对象中有个私有属性,对象外部无法访问,但是可以通过接口实现设置和访问。
如果看过上一篇的《JavaScript高级之闭包》文章,那么很快就可以解决上面的面试题。没错,JavaScript的私有属性封装就是通过闭包和局部变量实现的。
看下面的实际例子:
定义一个女孩的对象,有公开的“name”和私有的“secret”属性,
function Girl(name,boyfriend){
this.name = name;
var secret = boyfriend;//私有属性
//通过getSecret做接口,读取私有属性
this.getSecret = function(){
return secret;
}
this.setSecret = function(newSecret){
secret = newSecret;
}
}
var girl = new Girl('风暴女神','金刚狼');
alert(girl.name+'喜欢'+girl.getSecret());//读
girl.setSecret('激光男');//写
alert(girl.name+'喜欢'+girl.getSecret());//读
这样就实现了JavaScript对象的私有属性封装,只能通过提供的接口进行读写。
在实现JavaScript的私有属性之前,先来看看一道百度的面试题:
实现一个对象,对象中有个私有属性,对象外部无法访问,但是可以通过接口实现设置和访问。
如果看过上一篇的《JavaScript高级之闭包》文章,那么很快就可以解决上面的面试题。没错,JavaScript的私有属性封装就是通过闭包和局部变量实现的。
看下面的实际例子:
定义一个女孩的对象,有公开的“name”和私有的“secret”属性,
function Girl(name,boyfriend){
this.name = name;
var secret = boyfriend;//私有属性
//通过getSecret做接口,读取私有属性
this.getSecret = function(){
return secret;
}
this.setSecret = function(newSecret){
secret = newSecret;
}
}
var girl = new Girl('风暴女神','金刚狼');
alert(girl.name+'喜欢'+girl.getSecret());//读
girl.setSecret('激光男');//写
alert(girl.name+'喜欢'+girl.getSecret());//读
这样就实现了JavaScript对象的私有属性封装,只能通过提供的接口进行读写。
相关文章推荐
- javascript高级属性:私有 和 继承
- Ajax - JavaScript之实现私有属性、像C++和Java一样支持基于类的继承方法之例子
- javascript王者归来--公有和私有:属性的封装
- JavaScript中的私有/静态属性
- Javascript中的高级特性及特别对象、属性和方法
- 在javascript中的公共,私有,静态属性
- JavaScript中的高级特性及特别对象、属性和方法
- javascript私有属性与封装
- javaScript 利用闭包模拟对象的私有属性
- javaScript 利用闭包模拟对象的私有属性
- 如何在JavaScript中实现私有属性的写类方式(一)
- JavaScript中的高级特性及特别对象、属性和方法
- javascript: 高级技巧: window 对象也可以添加自定义属性, 无须等加载完毕
- JavaScript高级应用prototype的属性使用说明
- JavaScript中的私有/静态属性介绍
- JavaScript中实现私有属性的写类方式(1)
- Ajax - JavaScript之私有属性和使用JavaScript的信息隐藏
- JavaScript私有属性、实例属性、类属性定义及实践效果
- javascript面向对象技术基础(六)(作用域、闭包、模拟私有属性)
- 如何在JavaScript中实现私有属性的写类方式(一)