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。
所以,当我们遍历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可以直接和她们画等号的原因。)