javascript创建对象的方式(四)

在[url=http://redhacker.iteye.com/blog/1458580]上篇[/url]博客中,我们使用构造函数的方式创建对象,解决了创建对象友好性的问题,对于重复创建Function对象,我们只需要做如下改进就可以解决:


function _run(name) {
alert(name + " is running!");
}
function Person(name, age, sex) {
this.name = name;
this.age = age;
this.sex = sex;
this.run = _run(this.name);
}
var p1 = new Person("redhacker", 20, "男");
var p2 = new Person("wendy", 18, "女");
p1.run();
p2.run();


如上,将run方法对应的Function对象(js中每个function函数都是一个Function对象)提出去到外面定义,就达到了Function对象复用的目的。

或许有人对上面的写法还是感觉别扭,那看看如下的写法,或许你会感到更加亲切:

[code]
var _run = new Function("name","alert(name + ' is running!')");
function Person(name, age, sex) {
this.name = name;
this.age = age;
this.sex = sex;
this.run = _run(this.name);
}
var p1 = new Person("redhacker", 20, "男");
var p2 = new Person("wendy", 18, "女");
p1.run();
p2.run();
[/code]

至此,我们已经解决了[url=http://redhacker.iteye.com/blog/1457293]javascript创建对象的方式(二)[/url] 提出的两个问题了,但若要问还有没有什么改进的空间呢,答案是肯定了,我们在下一篇博客中再来谈一谈吧!

关于function及Function的区别可参考:[url]http://www.cnitblog.com/yemoo/archive/2007/09/25/34017.html[/url]

[color=gray]如果您觉得本文对您有益,请点击博文后的google广告,对作者表示支持,谢谢![/color]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值