一、数组检测
1.使用ARRAY.ISARRAY()
Array.isArray(obj)
例如:
Array.isArray([]) //true Array.isArray({}) //false
兼容性:
CHROME | FIREFOX | IE | OPERA | SAFARI |
5 | 4.0(2.0) | 9 | 10.5 | 5 |
可以使用以下方式,先检测是否支持Array.isArray
。
if(Array.isArray){ return Array.isArray(obj); }
2. 使用INSTANCEOF
arr instanceof Array
例如:
var arr=[]; console.log(arr instanceof Array); //true
3. 使用OBJECT.PROTOTYPE.TOSTRING方法
if( Object.prototype.toString.call(arr) === '[object Array]' ) { console.log("yes"); }
4.使用CONSTRUCTOR的方法
function isArray(obj){ return !!obj && Array === obj.constructor; }
二、类型检测
typeof操作符检测给定变量的数据类型
typeof operand //operand 是一个表达式,表示对象或原始值
以下是一些常见类型的返回结果,值得注意的是null返回的是object,其实对于引用类型的判断都为object。
TYPE | RESULT |
Undefined | “undefined” |
Null | “object” (see below) |
Boolean | “boolean” |
Number | “number” |
String | “string” |
Symbol (new in ECMAScript 2015) | “symbol” |
Host object (provided by the JS environment) | Implementation-dependent |
Function object (implements [[Call]] in ECMA-262 terms) | “function” |
Any other object | “object” |
三、对象类型检测
1. INSTANCEOF
用来检测 constructor.prototype
是否存在于object 的原型链上
使用方式:
object instanceof constructor
举个例子:
function A(){}; var a=new A(); a instanceof A //true a instanceof Object //true a.prototype instanceof Object //true
2. ISPROTOTYPEOF
只要是原型链所派生的实例的原型,会返回true
Object.prototype.isPrototypeOf(instance);
这里需要注意的是与instanceof的区别,在constructors被复写,而又没有重新制定的情况下,照样可以使用isPrototype
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之间(不含两个端点),超过这个范围,无法精确表示这个值。
总结
目前接触到的一些方法,如果有新的日后再更新。感兴趣的朋友们可以继续关注三水点靠木,好了,以上就是这篇文章的全部内容了,希望对大家的学习或者工作能带来一定的帮助。
Javascript中常用的检测方法小结
- Author -
daisy声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@