javascript--new之愚见

在面向对象的语言里,new的作用是创建一个类的实例,简单的来说就是创建一个对象的意思。如:

  
  var i = new Number( '1' );
  
  var b = new Boolean( true );

  var s = new String( 'a' );

  var f = new Function( 'alert( 1 );' );

  var obj = new Object;// var obj = new Object();

  var temp = function( a, b )

    {

       this.a = a;

       this.b = b;

    }

    var t = new temp;

这6种情况下typeof i,typeof b,typeof s,typeof f,typeof obj,typeof t都返回JS之'object'字符串

 

顺便说说,关于typeof,instanceof和constructor,大家知道可以用来进行对象的一些非空判断或类型辨别。这里说说第5,6种情况, obj instanceof Object返回true; t instanceof temp返回true且 t instanceof Object也返回true;这也就是Object和Function的一点区别了。这里扩展一下,凡是Function类型的对象都可以调用Object的prototype,但返过来就不行。记住:是类型的对象,比如temp只可以调用Function.prototype,但new temp既可以调用temp.prototype也可以调用Object.prototype。 
所以,当我们遍历new temp的所有prototype的时候,拿到的除了定义在temp内部的成员变量a,b外,还有temp.prototype的所有成员以及Object.prototype的所有成员。最后关于constructor,凡对象.constructor返回都是Function类型。即typeof XXX.constructor == 'function'返回true。比如上例中: new temp().constructor == temp返回true,但temp.constructor == Function返回true; new Object().constructor == Object返回true。 

最后回忆一下JS之Object,Function,Number,String,Boolean,undefined,后面一个就不说了。前面5个typeof一下都是'function'串。例:alert( typeof Object == 'function' );和alert( Object );就明了了。(这也就是为什么XXX.constructor可以直接和她们画等号的原因。)  

posted @ 2011-03-28 18:42  icysoul  阅读(128)  评论(0编辑  收藏  举报