使用隐藏的new来创建对象

 更新时间:2011年03月29日 00:17:52   作者:  
JQ中发现的,jQuery.Event类。估计作者是为了减少代码量。定义一个类,但不用new关键字去创建该类对象,而使用方法调用()方式去创建该对象。
很多时候我们是这样写类,然后使用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);

相关文章

  • jQuery+css实现炫目的动态块漂移效果

    jQuery+css实现炫目的动态块漂移效果

    这篇文章主要介绍了jQuery+css实现的动态块漂移效果,涉及jQuery基于随机数与时间函数动态操作页面元素样式的相关技巧,需要的朋友可以参考下
    2016-01-01
  • 分享一个asp.net pager分页控件

    分享一个asp.net pager分页控件

    分享一个asp.net pager分页控件,想要自定义控件的朋友可以参考下。
    2012-01-01
  • jQuery中last()方法用法实例

    jQuery中last()方法用法实例

    这篇文章主要介绍了jQuery中last()方法用法,实例分析了last()方法获取匹配元素集合中的最后一个元素时的使用技巧,需要的朋友可以参考下
    2015-01-01
  • jquery实现对联广告的方法

    jquery实现对联广告的方法

    这篇文章主要介绍了jquery实现对联广告的方法,以一个完整实例形式详细分析了jQuery对联广告的样式与功能实现方法,是非常实用的技巧,需要的朋友可以参考下
    2015-02-02
  • 基于Jquery的淡入淡出的特效基础练习

    基于Jquery的淡入淡出的特效基础练习

    基于Jquery的淡入淡出的特效基础练习实现代码,学习jquery的朋友可以参考下。
    2010-12-12
  • jQuery DataTables插件自定义Ajax分页实例解析

    jQuery DataTables插件自定义Ajax分页实例解析

    这篇文章主要为大家详细介绍了jQuery DataTables插件自定义Ajax分页的相关资料,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • jQuery实现监听下拉框选中内容发生改变操作示例

    jQuery实现监听下拉框选中内容发生改变操作示例

    这篇文章主要介绍了jQuery实现监听下拉框选中内容发生改变操作,结合实例形式分析了jQuery针对select选中触发change事件相关操作技巧,需要的朋友可以参考下
    2018-07-07
  • jquery BS,dialog控件自适应大小

    jquery BS,dialog控件自适应大小

    今天准备用jquery.alerts的开源控件,基于jquery的,代码很少,很容易就搞定。
    2009-07-07
  • jquery实现图片平滑滚动详解

    jquery实现图片平滑滚动详解

    这篇文章主要为大家详细介绍了jquery实现图片平滑滚动的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • 基于jQuery实现可编辑的表格

    基于jQuery实现可编辑的表格

    这篇文章主要为大家详细介绍了基于jQuery实现可编辑的表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12

最新评论