typeOf与 instanceof的区别

typeOf:
     typeOf操作符是确定一个变量是字符串,数值,布尔值还是undefine或者是object的最佳工具。
     var s=’tom’,str=‘22’;
     var b = true,
     var i = 22;
     var u ;
     var n = null;
     var o = new Object();
     var fun = function(){}

     typeof s;//’string'
     typeof str;//’string'
     typeof b; //‘boolean'
     typeof i;//’number'
     typeof u;//'undefine'
     typeof n;//'object'
     typeof o;//‘object' 
     typeof fun;//‘function'


instanceof:
     instanceof操作符是确定一个对象是什么类型的对象的工具。
     alert(person instanceof Object);//变量person是Object 对象吗?
     alert(colors instanceof Array);//变量colors是Array 对象吗?
     alert(pattern instanceof RegExp);//变量pattern是RegExp 对象吗?
所有引用类型的值都是Object的实例。


区别:typeof是判断变量是什么基本类型的;
          instanceof是判断对象到底是什么类型的;



constructor:
function  isArray(arr){
     return  typeof  arr == "object"  && arr.constructor == Array;
}
很多情况下,我们可以使用instanceof运算符或对象的constructor属性来检测对象是否为数组。例如很多JavaScript框架就是使用这两种方法来判断对象是否为数组类型。 但是检测在跨框架(cross-frame)页面中的数组时,会失败。原因就是在不同框架(iframe)中创建的数组不会相互共享其prototype属性
< script >
window.onload=function(){
var iframe_arr=new window.frames[0].Array;
alert(iframe_arr instanceof Array); // false
alert(iframe_arr.constructor == Array); // false
}
script >


跨原型链调用toString()方法:Object.prototype.toString()。可以解决上面的跨框架问题。 当Object.prototype.toString(o)执行后,会执行以下步骤: 1)获取对象o的class属性。 2)连接字符串:"[object "+结果(1)+"]" 3)返回 结果
Object.prototype.toString.call([]); // 返回 "[object Array]"
Object.prototype.toString.call(/reg/ig); // 返回 "[object RegExp]"

你可能感兴趣的:(javascript)