首页 >

使用隐藏的new来创建对象【jquery】

web前端|js教程使用隐藏的new来创建对象【jquery】
new,创建对象
web前端-js教程
很多时候我们是这样写类,然后使用new创建对象的。
手游全套源码,vscode怎么在终端输入,ubuntu dev fb,tomcat京太博客,爬虫文库格式,php 行读取 文件尾,亿人SEO教程小程序,娱乐网站源码程序,站帮网蓝色动力模板lzw
 
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);

改成这样的

开放卡 麻将 源码,ubuntu 串口终端软件,tomcat集群与调优,爬虫流程代码,php传输视频,海珠百度seo关键词优化lzw
 
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);

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

网盘系统设计源码,ubuntu关机日志分析,tomcat9如何下划线,爬虫抢九价,无数据库php网站源码,seo咨询面试lzw
 
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来创建对象【jquery】
  • nullJavascript中创建对象的五种方法实例【javascript】
  • nullJavascript中创建对象的五种方法实例【javascript】 | nullJavascript中创建对象的五种方法实例【javascript】 ...

    使用隐藏的new来创建对象【jquery】
  • JavaScript创建对象(3种方式)
  • JavaScript创建对象(3种方式) | JavaScript创建对象(3种方式) ...

    使用隐藏的new来创建对象【jquery】
  • JavaScript 创建对象: 方法一览与最佳实践
  • JavaScript 创建对象: 方法一览与最佳实践 | JavaScript 创建对象: 方法一览与最佳实践 ...