详解js中typeof、instanceof与constructor
2016-04-29 11:06
579 查看
typeof返回一个表达式的数据类型的字符串,返回结果为js基本的数据类型,包括number,boolean,string,object,undefined,function.语法为typeof(data) 或 typeof data
instanceof则为判断一个对象是否为某一数据类型,或一个变量是否为一个对象的实例;返回boolean类型
语法为 o instanceof A
以下为综合实例:
js中constructor较少使用,如果不是搜索到相关construtor相关的资料,我之前从没有注意到js还有这个函数。
使用typeof的一个不好的地方就是它会把Array还有用户自定义函数都返回为object
可以看到js.constructor返回的是一些字符串,大家都应该能看到这是一个function类型,此例为Number()为Number对象的构造函数,Number()用于将其参数转换为数字number类型,并返回转换结果(若不能转换则返回 NaN)。
因此在以后的js判断数据类型时可以使用以下方式来得到其详细数据类型
这里还要注意,constructor只能对已有变量进行判断,而typeof则可对未声明变量进行判断(返回undefined)。
原文来自:http://www.51obj.cn/
instanceof则为判断一个对象是否为某一数据类型,或一个变量是否为一个对象的实例;返回boolean类型
语法为 o instanceof A
以下为综合实例:
<script type="text/javascript"> alert("typeof(1):" + typeof(1));//number alert("typeof(\"abc\"):" + typeof("abc"));//string alert("typeof(true):" +typeof(true));//boolean alert("typeof(2009-2-4):" + typeof(2009-2-4));//number alert("typeof(\"2009-2-4\"):" + typeof("2009-2-4"));//string alert("typeof(m):" + typeof(m));//undefined var d=new Date(); alert("typeof(d):" + typeof(d));//object function Person(){}; alert("typeof(Person):" + typeof(Person));//function var a=new Array(); alert("typeof(a):" + typeof(a));//object alert("a instanceof Array:" + (a instanceof Array)); var h=new Person(); var o={}; alert("h instanceof Person:" + (h instanceof Person));//true alert("h instanceof Object:" + (h instanceof Object));//true alert("o instanceof Object:" + (o instanceof Object));//true alert(typeof(h));//object </script>
js中constructor较少使用,如果不是搜索到相关construtor相关的资料,我之前从没有注意到js还有这个函数。
使用typeof的一个不好的地方就是它会把Array还有用户自定义函数都返回为object
<script type="text/javascript"> var j=2; alert(typeof(j));//number alert("j.constructor:" + j.constructor);//function … alert(typeof(j.constructor));//function </script>
可以看到js.constructor返回的是一些字符串,大家都应该能看到这是一个function类型,此例为Number()为Number对象的构造函数,Number()用于将其参数转换为数字number类型,并返回转换结果(若不能转换则返回 NaN)。
因此在以后的js判断数据类型时可以使用以下方式来得到其详细数据类型
if((typeof o=="object") && (o.constructor==Number)){ … }
这里还要注意,constructor只能对已有变量进行判断,而typeof则可对未声明变量进行判断(返回undefined)。
原文来自:http://www.51obj.cn/
相关文章推荐
- js正则函数match、exec、test、search、replace、split使用介绍集合
- js的静态类
- JavaScript调试技巧之:快速定位
- js中利用prototype给类添加方法
- 学习之路——javascript
- js2
- 高手详解Javascript中的this指针
- js中cookie的操作
- js获取浏览器滚动条距离顶端的距离
- javascript双等号引起的类型转换,js隐性类型转换步骤
- Extjs搜索 重置搜索框 关于页码问题 向后台传递排序参数 向后台传递参数
- Jsp技术总结
- JavaScript基础学习(四)-Array对象
- JavaScript中的console.dir()函数介绍
- Lable语句用法
- 使用 ServiceStack.Text 序列化 json 比Json.net更快
- js动态替换数据的点击事件
- 使用JavaScript实现动态创建含合并单元格(行)的表单
- 在pc端和触控端支持滚动条
- 搭建json格式的webservice服务器