JavaScript数据类型判断的方法介绍(代码)
程序员文章站
2022-03-22 09:28:37
...
本篇文章给大家带来的内容是关于JavaScript数据类型判断的方法介绍(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
1、 常用的typeof
对于array、object、null的判断是不友好的,可以看下图的执行结果。
var obj = { number:123, string: '123', bool: true, obj: {}, arr: [], n: null, undef: undefined, fn: function () {} } for(key in obj) { console.log(key + ": " + typeof obj[key]) }
2. instanceof
instanceof测试构造函数的prototype属性是否出现在对象的原型链中的任何位置。
如果你了解原型链,你会知道原型链的复杂性,instanceof得到的值并不是固定不变的,它会沿着原型链查找,最明显的是所有的基本数据类型都继承与Object.protype.
[任何数据类型] instanceof Object > true
如下图:
3.最终方案:Object.prototype.toString.call()
下面是兼容性方案最好、最全面、也是最有效的:
下面有两种实现方式(原型方法和全局方法),可以根据自己的需要选择。
(function () { function isType(type,data) { // data是全局方法时使用的,原型方法可不填 return Object.prototype.toString.call(data || this) === '[object ' + type + ']' } // 全局方法支持null和undefined // window.isType = isType // 添加到数据类型的原型中,不支持null和undefined Object.defineProperty(Object.prototype,'isType',{ value:isType, writable:true, enumerable:false, configurable:true }); })()
使用方式:
var str = 'abc'; // 全局方法 isType('String', str) // True // 原型方法 str.isType('String')
测试代码:
var obj = { test: { number:123, string: '123', obj: {}, bool: true, arr: [], n: null, undef: undefined, fn: function () { } } } // 原型方法不支持null和undefined,请用“===” console.log(obj.test.number.isType('Number')) console.log(obj.test.number.isType('String')) console.log(obj.test.string.isType('String')) console.log(obj.test.string.isType('Number')) console.log(obj.test.obj.isType('Object')) console.log(obj.test.obj.isType('Array')) console.log(obj.test.arr.isType('Array')) console.log(obj.test.arr.isType('Object')) console.log(obj.test.fn.isType('Function')) console.log(obj.test.fn.isType('Object'))
本篇文章到这里就已经全部结束了,更多其他精彩内容可以关注PHP中文网的JavaScript视频教程栏目!!!
以上就是JavaScript数据类型判断的方法介绍(代码)的详细内容,更多请关注其它相关文章!
上一篇: 如何查看linux的网卡速率
下一篇: linux出现乱码怎样解决
推荐阅读
-
JS判断浏览器类型与版本的实现代码_javascript技巧
-
详细介绍javascript使用prototype实现OOP继承的方法
-
如何用JavaScript去判断是否为微信扫码的方法
-
js的各种数据类型判断的介绍
-
Javascript 中判断是谷歌浏览器和IE浏览器的方法
-
如何用JavaScript代码获取left和top值的方法详解
-
具体介绍javascript使用两种方式动态生成css代码的详情
-
JavaScript中的apply()方法和call()方法使用介绍_javascript技巧
-
HTML5多线程JavaScript解决方案Web Worker-专用Worker和共享Worker的详细代码介绍
-
判断文件是否正在被使用的JS代码_javascript技巧