复制代码 代码如下:
//创建一个新的用户对象,接受一个有许多属性的对象作为参数
function User(properties)
{
//遍历该对象的所有属性,并保证其作用域正确
for(var i in properties){
(function(which){
var p=i;
//创建此属性的一个新的读取器(getter)
which["get"+p]=function(){
return properties[p];
};
//创建此属性的一个新的设置器(setter)
which["set"+p]=function(val)
{
properties[p]=val;
};
})(this);
}
}
//创建一个新的用户对象实例,并把具有两个属性的一个对象传入作为参数
var user=new User({name:"Bob",age:44});
//读取属性值
alert(user.getname());
//设置属性值
user.setage(23);
您可能感兴趣的文章:
- 深入理解JavaScript中的块级作用域、私有变量与模块模式
- JavaScript的作用域和块级作用域概念理解
- 为什么JavaScript没有块级作用域
- Javascript中的作用域及块级作用域
- JavaScript匿名函数之模仿块级作用域
- 解析JavaScript模仿块级作用域
- 通过函数作用域和块级作用域看javascript的作用域链
- JavaScript使用闭包模仿块级作用域操作示例
- js类中的公有变量和私有变量
- JavaScript私有变量实例详解
- JS块级作用域和私有变量实例分析