javascript设计模式之对象工厂函数与构造函数详解(2)


var p = new Person('张三', 29, '软件工程师');
//使用对象构造函数创建对象,
//每个对象的constructor属性,引用这个构造函数
console.info(p.constructor === Person);
 //true如何避免“忘记”new?可以使用arguments.callee解决这个问题     
//了解arguments.callee的作用    
function TestArgumentsCallee()
 {         
console.info(this);         
console.info(this instanceof TestArgumentsCallee);        
 console.info(this instanceof arguments.callee);    
 };     
TestArgumentsCallee(); //window                                         

//false                                         
//false     
new TestArgumentsCallee(); 
//TestArgumentsCallee             
//true                                             

//true

于是,可以直接用arguments.callee

复制代码 代码如下:


 //避免忘记new    
 function MyObject(value)
{        
 if (!(this instanceof arguments.callee))

{            
 //如果调用者忘记加上new了,就加上new再调用一次             

return new MyObject(value);        
 }        
 this.prop = value;    
 }     
//测试     
var obj1 = new MyObject(100);    
 console.info(obj1.prop);//100    
 var obj2 = MyObject(200);       
console.info(obj2.prop); //200

以上内容就是javascript设计模式之对象工厂函数与构造函数详解,希望大家喜欢。

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wgdwgw.html