手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >使用隐藏的new来创建对象
使用隐藏的new来创建对象
摘要:很多时候我们是这样写类,然后使用new创建对象的。复制代码代码如下:functionPerson(name,age){this.name=n...

很多时候我们是这样写类,然后使用new创建对象的。

复制代码 代码如下:

function Person(name,age){

this.name=name;

this.age=age;

}

Person.prototype={

setName : function(n){this.name=n;},

getName : function(){return this.name;}

}

var p = new Person('jack',25);

改成这样的

复制代码 代码如下:

function Person(name,age){

//条件改为(this==window)或(this==self)或(this.constructor!=Object)

if(!this.setName){

return new Person(name,age);

}

this.name=name;

this.age=age;

}

Person.prototype={

setName : function(n){this.name=n;},

getName : function(){return this.name;}

}

var p = Person('jack',25);

注意该类较最上面的写类方式中多了以下

复制代码 代码如下:

if(!this.setName){

return new Person(name,age);

}

好,创建类的实例(对象)方式也变成了如下

复制代码 代码如下:

var p = Person('jack',25);

这种创建方式(函数调用)较上面的少了“new_”,new和空格,实际上是在类内部new了。而这样方式每次创建对象可以减少4个byte。

如果把类内部的if判断条件换成非prototype上的属性,如this.name。程序会提示出错:too much recursion

复制代码 代码如下:

function Person(name,age){

if(!this.name){

return new Person(name,age);

}

this.name=name;

this.age=age;

}

Person.prototype={

setName : function(n){this.name=n;},

getName : function(){return this.name;}

}

var p = Person('jack',25);

【使用隐藏的new来创建对象】相关文章:

如何用JS取得网址中的文件名

使用JavaScript刷新网页的方法

获取对象

7个有用的jQuery代码片段分享

javascript元素动态创建实现方法

正宗的日历(含农历)

会自动逐行上升的文本框

在JavaScript应用中使用RequireJS来实现延迟加载

JS创建对象几种不同方法详解

由ReactJS的Hello world说开来

精品推荐
分类导航