Javascript中常用的检测方法小结


Posted in Javascript onOctober 08, 2016

一、数组检测

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 相关文章推荐
document.body.scrollTop 值总为0的解决方法 比较常见的标准问题
Nov 30 Javascript
小议Javascript中的this指针
Mar 18 Javascript
IE6、IE7中setAttribute不支持class/for/rowspan/colspan等属性
Aug 28 Javascript
自己动手实现jQuery Callbacks完整功能代码详解
Nov 25 Javascript
jQuery中:animated选择器用法实例
Dec 29 Javascript
微信中一些常用的js方法汇总
Mar 12 Javascript
浅谈jQuery的offset()方法及示例分享
Jul 17 Javascript
jQuery中delegate()方法的用法详解
Oct 13 Javascript
js代码延迟一定时间后执行一个函数的实例
Feb 15 Javascript
Bootstrap实现可折叠分组侧边导航菜单
Mar 07 Javascript
vue左右侧联动滚动的实现代码
Jun 06 Javascript
vue-cli+axios实现文件上传下载功能(下载接收后台返回文件流)
May 10 Javascript
微信小程序 前端源码逻辑和工作流详解
Oct 08 #Javascript
AngularJS 2.0入门权威指南
Oct 08 #Javascript
省市区三级联动jquery实现代码
Apr 15 #Javascript
微信小程序 数据访问实例详解
Oct 08 #Javascript
Bootstrap Table的使用总结
Oct 08 #Javascript
js HTML5手机刮刮乐代码
Sep 29 #Javascript
原生js的RSA和AES加密解密算法
Oct 08 #Javascript
You might like
一个目录遍历函数
2006/10/09 PHP
PHP 各种排序算法实现代码
2009/08/20 PHP
基于pear auth实现登录验证
2010/02/26 PHP
深入PHP empty(),isset(),is_null()的实例测试详解
2013/06/06 PHP
PHP中数组的分组排序实例
2014/06/01 PHP
PHP测试框架PHPUnit组织测试操作示例
2018/05/28 PHP
javascript学习笔记(九)javascript中的原型(prototype)及原型链的继承方式
2011/04/12 Javascript
基于jquery实现省市区三级联动效果
2015/12/25 Javascript
全面解析JavaScript中的valueOf与toString方法(推荐)
2016/06/14 Javascript
jquery dataview数据视图插件使用方法
2016/12/23 Javascript
JS出现失效的情况总结
2017/01/20 Javascript
JS实现动态修改table及合并单元格的方法示例
2017/02/20 Javascript
深入理解JavaScript 参数按值传递
2017/05/24 Javascript
关于javascript获取内联样式与嵌入式样式的实例
2017/06/01 Javascript
JavaScript获取tr td 的三种方式全面总结(推荐)
2017/08/15 Javascript
浅谈vue父子组件怎么传值
2018/07/21 Javascript
layui问题之渲染数据表格时,仅出现10条数据的解决方法
2019/09/12 Javascript
解决vue无法侦听数组及对象属性的变化问题
2020/07/17 Javascript
关于JavaScript中异步/等待的用法与理解
2020/11/18 Javascript
python控制台显示时钟的示例
2014/02/24 Python
django基础之数据库操作方法(详解)
2017/05/24 Python
Python Pillow Image Invert
2019/01/22 Python
Python使用post及get方式提交数据的实例
2019/01/24 Python
Python 实现平台类游戏添加跳跃功能
2020/03/27 Python
django 模型中的计算字段实例
2020/05/19 Python
Python虚拟环境venv用法详解
2020/05/25 Python
html5 viewport使用方法示例详解
2013/12/02 HTML / CSS
KIEHL’S科颜氏官方旗舰店:源自美国的顶级护肤品牌
2018/06/07 全球购物
Douglas意大利官网:购买香水和化妆品
2020/05/27 全球购物
共筑中国梦演讲稿
2014/04/23 职场文书
远程教育学习心得体会
2016/01/23 职场文书
浅谈JS的原型和原型链
2021/06/04 Javascript
在Spring-Boot中如何使用@Value注解注入集合类
2021/08/02 Java/Android
关于Python中*args和**kwargs的深入理解
2021/08/07 Python
德劲DE1102数字调谐收音机机评
2022/04/07 无线电
Java Spring读取和存储详细操作
2022/08/05 Java/Android