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