• javascript:typeof与instanceof区别


    from:http://www.wxwdesign.cn/article/skills/javascript_typeof_instanceof.htm 

    JavaScript中typeof和instanceof常用来判断一个变量是否为空,或者是什么类型的。但它们之间还是有区别的:


    typeof

    typeof 是一个一元运算,放在一个运算数之前,运算数可以是任意类型。
    它返回值是一个字符串,该字符串说明运算数的类型。,typeof一般只能返回如下几个结果:number,boolean,string,function,object,undefined。 我们可以使用typeof来获取一个变量是否存在,如if(typeof a!="undefined"){alert("ok")},而不要去使用if(a)因为如果a不存在(未声明)则会出错,对于Array,Null等特 殊对象使用typeof一律返回object,这正是typeof的局限性。

    网上的一个小例子:

    instanceof

    instance:实例,例子

    a instanceof b?alert("true"):alert("false");   //a是b的实例?真:假

    instanceof 用于判断一个变量是否某个对象的实例,如var a=new Array();alert(a instanceof Array);会返回true,同时alert(a instanceof Object)也会返回true;这是因为Array是object的子类。再如:function test(){};var a=new test();alert(a instanceof test)会返回

    谈到instanceof我们要多插入一个问题,就是function的arguments,我们大家也许都认为arguments是一个Array,但如果使用instaceof去测试会发现arguments不是一个Array对象,尽管看起来很像。

    另外:

    测试 var a=new Array();if (a instanceof Object) alert('Y');else alert('N');
    得'Y’ 

    但 if (window instanceof Object) alert('Y');else alert('N');

    得'N'

    所以,这里的instanceof测试的object是指js语法中的object,不是指dom模型对象。

    使用typeof会有些区别
    alert(typeof(window) 会得 object

  • 相关阅读:
    ES6_函数方法
    Node_初步了解(3)回调,作用域,上下文
    ES6_入门(4)_数组的解构赋值
    ES6_入门(3)_顶层对象属性
    ES6_入门(2)_const命令
    ES6_入门(1)_let命令
    Node_初步了解(2)
    Node_初步了解(1)
    树的基本知识
    JS_高程5.引用类型(6)Array类型的位置方法,迭代方法,归并方法
  • 原文地址:https://www.cnblogs.com/xuan52rock/p/4538037.html
Copyright © 2020-2023  润新知