码迷,mamicode.com
首页 > Web开发 > 详细

详解js中typeof、instanceof与constructor

时间:2014-11-20 10:12:56      阅读:214      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   io   ar   color   os   使用   sp   

详解js中typeof、instanceof与constructor

typeof返回一个表达式的数据类型的字符串,返回结果为js基本的数据类型,包括number,boolean,string,object,undefined,function.语法为typeof(data) 或 typeof data

instanceof则为判断一个对象是否为某一数据类型,或一个变量是否为一个对象的实例;返回boolean类型
语法为 o instanceof A

以下为综合实例:


bubuko.com,布布扣
 1bubuko.com,布布扣<script type="text/javascript">
 2bubuko.com,布布扣<!
 3bubuko.com,布布扣alert("typeof(1):" + typeof(1));//number
 4bubuko.com,布布扣alert("typeof(\"abc\"):" + typeof("abc"));//string
 5bubuko.com,布布扣alert("typeof(true):" +typeof(true));//boolean
 6bubuko.com,布布扣alert("typeof(2009-2-4):" + typeof(2009-2-4));//number
 7bubuko.com,布布扣alert("typeof(\"2009-2-4\"):" + typeof("2009-2-4"));//string
 8bubuko.com,布布扣alert("typeof(m):" + typeof(m));//undefined
 9bubuko.com,布布扣var d=new Date();
10bubuko.com,布布扣alert("typeof(d):" + typeof(d));//object
11bubuko.com,布布扣function Person(){};
12bubuko.com,布布扣alert("typeof(Person):" + typeof(Person));//function
13bubuko.com,布布扣var a=new Array();
14bubuko.com,布布扣alert("typeof(a):" + typeof(a));//object
15bubuko.com,布布扣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

bubuko.com,布布扣
1bubuko.com,布布扣<script type="text/javascript">
2bubuko.com,布布扣<!
3bubuko.com,布布扣var j=2;
4bubuko.com,布布扣alert(typeof(j));//number
5bubuko.com,布布扣alert("j.constructor:" + j.constructor);//function …
6bubuko.com,布布扣alert(typeof(j.constructor));//function
7bubuko.com,布布扣//–>
8bubuko.com,布布扣</script>
bubuko.com,布布扣

 

查看演示

bubuko.com,布布扣

可以看到js.constructor返回的是一些字符串,大家都应该能看到这是一个function类型,此例为Number()为Number对象的构造函数,Number()用于将其参数转换为数字number类型,并返回转换结果(若不能转换则返回 NaN)。

因此在以后的js判断数据类型时可以使用以下方式来得到其详细数据类型

1bubuko.com,布布扣if((typeof o=="object") && (o.constructor==Number)){
2bubuko.com,布布扣
3bubuko.com,布布扣}

这里还要注意,constructor只能对已有变量进行判断,而typeof则可对未声明变量进行判断(返回undefined)。

原文来自:http://www.51obj.cn/

详解js中typeof、instanceof与constructor

标签:style   blog   http   io   ar   color   os   使用   sp   

原文地址:http://www.cnblogs.com/shsgl/p/4109869.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!