JS判断数据类型的4种方法
4种判断方法分别是:
- typeof
- instanceof
- prototype属性
- constructor属性
可判断的类型对比如下图:

实践代码如下:
1 // 构造函数名方法
2 function getConstructorName(data) {
3 return (data === undefined || data === null) ? data : (data.constructor && data.constructor.toString().match(/function\s*([^(]*)/)[1]);
4 }
5
7 // 对象原型方法
8 // 不能判断自定义函数对象类型
9 function getPrototypeName(data) {
10 return Object.prototype.toString.call(data).slice(8, -1);
11 }
12
13 // 自定义的构造函数
14 function Func() {
15 this.attr = 33;
16 }
17
18 var newObj = new Func(),
19 num = 123,
20 arr = [];
21
22 console.group("检测自定义构造函数实例");
23 console.log(getConstructorName(newObj)); // Func
24 console.log(getPrototypeName(newObj)); // Object ;仅能识别为对象
25 console.log(newObj instanceof Func); // true
26 console.log(typeof newObj); // object ;仅能识别为对象
27 console.groupEnd();
28
29 console.group("检测数值类");
30 console.log(getConstructorName(num)); // Number
31 console.log(getPrototypeName(num)); // Number
32 // console.log(num instanceof Number); // 数值类不是对象不能使用该方法
33 console.log(typeof num); // number
34 console.groupEnd();
35
36 console.group("检测数组类");
37 console.log(getConstructorName(arr)); // Array
38 console.log(getPrototypeName(arr)); // Array
39 console.log(arr instanceof Array); // true
40 console.log(typeof arr); // object ;仅能识别为对象
41 console.groupEnd();
JS判断数据类型的4种方法的更多相关文章
- JS 判断数据类型的三种方法
说到数据类型,我们先理一下JavaScript中常见的几种数据类型: 基本类型:string,number,boolean 特殊类型:undefined,null 引用类型:Object,Functi ...
- js 判断数据类型的几种方法
判断js中的数据类型有一下几种方法:typeof.instanceof. constructor. prototype. $.type()/jquery.type(),接下来主要比较一下这几种方法的异 ...
- js判断数据类型的四种方法
1.typeof typeof是一个操作符,其右侧跟一个一元表达式,并返回这个表达式的数据类型.返回的结果用该类型的字符串(全小写字母)形式表示,包括number,string,boolean,und ...
- [转]js判断数据类型的四种方法
原文地址:https://www.cnblogs.com/crackedlove/p/10331317.html 1.typeof typeof是一个操作符,其右侧跟一个一元表达式,并返回这个表达式的 ...
- js中判断数据类型的四种方法总结
js中判断数据类型的四种方法 前言 在js中,我们经常需要判断数据的类型,那么哪些方法可以用来判断数据的类型呢?哪种方法判断数据类型最准确呢? 我们来一个个分析: 1.typeof typeof是一个 ...
- javascript 判断数据类型的几种方法
javascript 判断数据类型的几种方法一.typeof 直接返回数据类型字段,但是无法判断数组.null.对象 typeof 1 "number" typeof NaN &q ...
- JS中判断数据类型的几种方法
1⃣️首先我们来了解一下js中的数据类型 1.基本数据类型:Undefined.Null.Boolean.Number.String(值类型) 2.复杂数据类型:Object(引用类型) (值类型和引 ...
- js判断类型的四种方法
typeof:使用typeof可以很方便的判断六种类型:undefined.boolean.string.number.object.function 数组和null会被判断为object类型 ins ...
- 判断数组的方法/判断JS数据类型的四种方法
参考文: 以下 3 个判断数组的方法,请分别介绍它们之间的区别和优劣Object.prototype.toString.call() . instanceof 以及 Array.isArray() h ...
- js中判断数据类型的4中方法
注意: js中数据类型有7种(number, boolean, string, null, undefined, object, Symbol(es6新增)) 原始数据类型: number, stri ...
随机推荐
- Word07 评审会会议秩序册office真题
1.课程的讲解之前,先来对题目进行分析,首先需要在考生文件夹下,将Wrod素材.docx文件另存为Word.docx,后续操作均基于此文件,否则不得分. 2.这一步非常的简单,打开下载素材文件,在[文 ...
- js导出表格到excel(合并头)
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- vue项目前台带表格的页面,让表格根据屏幕大小自适应高度,小屏幕时不出现多个滚动条
参见馆藏库房系统, 右侧整体结构一般如下 <el-container class="ml10 mr10 br7 bgw"> <el-main> // el- ...
- vue界面显示无效的token
返回登陆界面,重新登陆 登陆成功
- Oracle查看异常未提交事务
1.查看归档日志都有哪些 SELECT * from v$archived_log 2.查看某个SCN号的归档文件是否存在 SELECT * from v$archived_log WHERE 113 ...
- 肖sir__ 代码题 ___华为od练习
www.online1987.com 这个网站,有概率看到机考原题,后续内招,这个网站做到了原题
- Unity 消息机制
最近有新项目需要和同事合作开发,他做UI 我做网络层,做着做着发现 如果我们要相对独立完成自己的开发任务,那我们的代码耦合得减少,不然 一个人代码有大改的时候,另一个人也要进行大幅修改,这样不便于后期 ...
- Linux系统安装&VMware安装三
第十四步: 开始安装
- Qt实现带有映射关系的进度条
1.编写继承自widget的新类,这里我们定义为colorWidget; 2.在colorWidget中添加私有变量QVector<QRect> m_rects,用于存放进度条的不同区间( ...
- vue后台管理系统——用户管理模块
电商后台管理系统的功能--用户管理模块 1. 用户管理概述 通过后台管理用户的账号信息,具体包括用户信息的展示.添加.修改.删除.角色分配.账号启用/注销等功能. 用户信息列表展示 添加用户 修改用户 ...