Javascript中常用的检测方法小结

一、数组检测

1.使用ARRAY.ISARRAY()

rush:js;"> Array.isArray(obj)

例如:

rush:js;"> Array.isArray([]) //true Array.isArray({}) //false

兼容性:

可以使用以下方式,先检测是否支持Array.isArray

rush:js;"> if(Array.isArray){ return Array.isArray(obj); }

2. 使用INSTANCEOF

rush:js;"> arr instanceof Array

例如:

rush:js;"> var arr=[]; console.log(arr instanceof Array); //true

3. 使用OBJECT.PROTOTYPE.TOSTRING方法

rush:js;"> if( Object.prototype.toString.call(arr) === '[object Array]' ) { console.log("yes"); }

4.使用CONSTRUCTOR的方法

rush:js;"> function isArray(obj){ return !!obj && Array === obj.constructor; }

二、类型检测

typeof操作符检测给定变量的数据类型

rush:js;"> typeof operand //operand 是一个表达式,表示对象或原始值

以下是一些常见类型的返回结果,值得注意的是null返回的是object,其实对于引用类型的判断都为object。

三、对象类型检测

1. INSTANCEOF

用来检测 constructor.prototype是否存在于object 的原型链上

使用方式:

rush:js;"> object instanceof constructor

举个例子:

rush:js;"> function A(){}; var a=new A(); a instanceof A //true a instanceof Object //true a.prototype instanceof Object //true

2. ISPROTOTYPEOF

只要是原型链所派生的实例的原型,会返回true

rush:js;"> Object.prototype.isPrototypeOf(instance);

这里需要注意的是与instanceof的区别,在constructors被复写,而又没有重新制定的情况下,照样可以使用isPrototype

rush:js;"> var A = { //something } var B = Object.create(A); var C = Object.create(B);

console.log(A.isPrototypeOf(C)); // true
console.log(C instanceof A); //TypeError

3. HASOWNPROPERTY

hasOwnproperty() 方法用来判断某个对象是否含有指定的自身属性

4. OBJECT.IS()

用来比较两个值是否严格相等,与===相同

四、基本类型检测

NUMBER

Number.isFinite()

用来检查一个数值是否为有限的(finite)

Number.isNaN()

用来检查一个值是否为NaN

Number.isInteger()

用来判断一个值是否为整数。在JavaScript中,整数和浮点数是同样的储存方法,所以1和1.0为同一个值.

Number.isSafeInteger()

JavaScript能够准确表示的整数范围在-2^53到2^53之间(不含两个端点),超过这个范围,无法精确表示这个值。

总结

目前接触到的一些方法,如果有新的日后再更新。感兴趣的朋友们可以继续关注编程之家,好了,以上就是这篇文章的全部内容了,希望对大家的学习或者工作能带来一定的帮助。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...