码迷,mamicode.com
首页 > Web开发 > 详细

js中检测数据类型的几种方式

时间:2018-11-10 21:14:53      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:基本数据   new   fun   cti   作用   prototype   一个   字符串   on()   

1、typeof
一元运算符,用来检测数据类型。只可以检测number,string,boolean,object,function,undefined。
对于基本数据类型是没有问题的,但是遇到引用数据类型是不起作用的(无法细分对象)
  let str = ‘{}‘;
    let fn = function(){};
    let obj = {};
    let ary = [];
    let rg = /\d/;
    console.log(typeof str);//string
    console.log(typeof fn);//function
    console.log(typeof obj);//object
    console.log(typeof ary);//object
    console.log(typeof rg);//object

  

2、instanceof(二元运算符,需要两个操作数)
 检测某个对象是不是另外一个对象的实例
instanceof只能用来判断对象和函数,不能用来判断字符串和数字
let arr = [1,2,3];
console.log(arr instanceof Array);//true  检测arr是不是内置类Array的实例

 

3、constructor
js中所有对象都继承于Object,constructor是其中的一个属性。默认指向实例的构造函数(可以修改)
function fns (){}
let f = new fns;
console.log(f.constructor === fns);//true
console.log(f.constructor.name);//fns构造函数名称
//constructor属性并非一定指向构造函数,他也可以修改、变更

 

4、Object.prototype.toString.call
JavaScript中,通过Object.prototype.toString方法,判断某个对象值属于哪种内置类型
let date = new Date;
console.log(Object.prototype.toString.call(date));//[object Date]
let re = ‘/\d+g/‘;
console.log(Object.prototype.toString.call(re));//[object String]
let sz = [2,3,4];
console.log(Object.prototype.toString.call(sz));//[object Array]
let hs = function(){};
console.log(Object.prototype.toString.call(hs));//[object Function]

 

js中检测数据类型的几种方式

标签:基本数据   new   fun   cti   作用   prototype   一个   字符串   on()   

原文地址:https://www.cnblogs.com/theblogs/p/9940345.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!