最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JavaScript数据类型判断的方法介绍(代码)

来源:动视网 责编:小采 时间:2020-11-27 19:26:55
文档

JavaScript数据类型判断的方法介绍(代码)

JavaScript数据类型判断的方法介绍(代码):本篇文章给大家带来的内容是关于JavaScript数据类型判断的方法介绍(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。1、 常用的typeof对于array、object、null的判断是不友好的,可以看下图的执行结果。var obj = { n
推荐度:
导读JavaScript数据类型判断的方法介绍(代码):本篇文章给大家带来的内容是关于JavaScript数据类型判断的方法介绍(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。1、 常用的typeof对于array、object、null的判断是不友好的,可以看下图的执行结果。var obj = { n


本篇文章给大家带来的内容是关于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数据类型判断的方法介绍(代码)

JavaScript数据类型判断的方法介绍(代码):本篇文章给大家带来的内容是关于JavaScript数据类型判断的方法介绍(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。1、 常用的typeof对于array、object、null的判断是不友好的,可以看下图的执行结果。var obj = { n
推荐度:
标签: 方法 判断 介绍
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top