日期:2014-05-16  浏览次数:20318 次

javascript创建对象的方式(四)
在上篇博客中,我们使用构造函数的方式创建对象,解决了创建对象友好性的问题,对于重复创建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对象复用的目的。

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

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();


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

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