详解js中typeof、instanceof与constructor
详解js中typeof、instanceof与constructor
typeof返回一个表达式的数据类型的字符串,返回结果为js基本的数据类型,包括number,boolean,string,object,undefined,function.语法为typeof(data) 或 typeof data
instanceof则为判断一个对象是否为某一数据类型,或一个变量是否为一个对象的实例;返回boolean类型
语法为 o instanceof A
以下为综合实例:
 1![]() <script type="text/javascript">
<script type="text/javascript">
2![]() <!–
<!–
3![]() alert("typeof(1):" + typeof(1));//number
alert("typeof(1):" + typeof(1));//number
4![]() alert("typeof(\"abc\"):" + typeof("abc"));//string
alert("typeof(\"abc\"):" + typeof("abc"));//string
5![]() alert("typeof(true):" +typeof(true));//boolean
alert("typeof(true):" +typeof(true));//boolean
6![]() alert("typeof(2009-2-4):" + typeof(2009-2-4));//number
alert("typeof(2009-2-4):" + typeof(2009-2-4));//number
7![]() alert("typeof(\"2009-2-4\"):" + typeof("2009-2-4"));//string
alert("typeof(\"2009-2-4\"):" + typeof("2009-2-4"));//string
8![]() alert("typeof(m):" + typeof(m));//undefined
alert("typeof(m):" + typeof(m));//undefined
9![]() var d=new Date();
var d=new Date();
10![]() alert("typeof(d):" + typeof(d));//object
alert("typeof(d):" + typeof(d));//object
11![]() function Person(){};
function Person(){};
12![]() alert("typeof(Person):" + typeof(Person));//function
alert("typeof(Person):" + typeof(Person));//function
13![]() var a=new Array();
var a=new Array();
14![]() alert("typeof(a):" + typeof(a));//object
alert("typeof(a):" + typeof(a));//object
15![]() alert("a instanceof Array:" + (a instanceof Array));
alert("a instanceof Array:" + (a instanceof Array));
16var h=new Person(); 17var o={}; 18alert("h instanceof Person:" + (h instanceof Person));//true 19alert("h instanceof Object:" + (h instanceof Object));//true 20alert("o instanceof Object:" + (o instanceof Object));//true 21alert(typeof(h));//object 22//–> 23</script>
 <script type="text/javascript">
<script type="text/javascript">2
 <!–
<!–3
 alert("typeof(1):" + typeof(1));//number
alert("typeof(1):" + typeof(1));//number4
 alert("typeof(\"abc\"):" + typeof("abc"));//string
alert("typeof(\"abc\"):" + typeof("abc"));//string5
 alert("typeof(true):" +typeof(true));//boolean
alert("typeof(true):" +typeof(true));//boolean6
 alert("typeof(2009-2-4):" + typeof(2009-2-4));//number
alert("typeof(2009-2-4):" + typeof(2009-2-4));//number7
 alert("typeof(\"2009-2-4\"):" + typeof("2009-2-4"));//string
alert("typeof(\"2009-2-4\"):" + typeof("2009-2-4"));//string8
 alert("typeof(m):" + typeof(m));//undefined
alert("typeof(m):" + typeof(m));//undefined9
 var d=new Date();
var d=new Date();10
 alert("typeof(d):" + typeof(d));//object
alert("typeof(d):" + typeof(d));//object11
 function Person(){};
function Person(){};12
 alert("typeof(Person):" + typeof(Person));//function
alert("typeof(Person):" + typeof(Person));//function13
 var a=new Array();
var a=new Array();14
 alert("typeof(a):" + typeof(a));//object
alert("typeof(a):" + typeof(a));//object15
 alert("a instanceof Array:" + (a instanceof Array));
alert("a instanceof Array:" + (a instanceof Array));16var h=new Person(); 17var o={}; 18alert("h instanceof Person:" + (h instanceof Person));//true 19alert("h instanceof Object:" + (h instanceof Object));//true 20alert("o instanceof Object:" + (o instanceof Object));//true 21alert(typeof(h));//object 22//–> 23</script>
js中constructor较少使用,如果不是搜索到相关construtor相关的资料,我之前从没有注意到js还有这个函数。
使用typeof的一个不好的地方就是它会把Array还有用户自定义函数都返回为object
1![]() <script type="text/javascript">
<script type="text/javascript">
2![]() <!–
<!–
3![]() var j=2;
var j=2;
4![]() alert(typeof(j));//number
alert(typeof(j));//number
5![]() alert("j.constructor:" + j.constructor);//function …
alert("j.constructor:" + j.constructor);//function …
6![]() alert(typeof(j.constructor));//function
alert(typeof(j.constructor));//function
7![]() //–>
//–>
8![]() </script>
</script>
 <script type="text/javascript">
<script type="text/javascript">2
 <!–
<!–3
 var j=2;
var j=2;4
 alert(typeof(j));//number
alert(typeof(j));//number5
 alert("j.constructor:" + j.constructor);//function …
alert("j.constructor:" + j.constructor);//function …6
 alert(typeof(j.constructor));//function
alert(typeof(j.constructor));//function7
 //–>
//–>8
 </script>
</script>

可以看到js.constructor返回的是一些字符串,大家都应该能看到这是一个function类型,此例为Number()为Number对象的构造函数,Number()用于将其参数转换为数字number类型,并返回转换结果(若不能转换则返回 NaN)。
因此在以后的js判断数据类型时可以使用以下方式来得到其详细数据类型
1![]() if((typeof o=="object") && (o.constructor==Number)){
if((typeof o=="object") && (o.constructor==Number)){
2![]() …
…
3![]() }
}
 if((typeof o=="object") && (o.constructor==Number)){
if((typeof o=="object") && (o.constructor==Number)){2
 …
…3
 }
}这里还要注意,constructor只能对已有变量进行判断,而typeof则可对未声明变量进行判断(返回undefined)。
原文来自:http://www.51obj.cn/
 
                    
                     
                    
                 
                    
                
 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号 
