视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
js中类型检测的四种方法介绍(代码)
2020-11-27 19:32:17 责编:小采
文档


本篇文章给大家带来的内容是关于js中类型检测的四种方法介绍(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

从最垃圾的方式到最牛逼的方式依次排列为:typeof --> constructor --> instanceof --> toString

1.typeof

检测对象类型太过模糊,function、object、array类型都会返回object,所以此方法垃圾,但实用性很强,气场很强大

2.constructor

实例对象的构造函数 (实例对象.constructor),返回构造函数,可以分辨出类型

var str = 'abc';
 var num = 100;
 var arr = new Array();
 var date = new Date();
 alert(str.constructor);
 alert(num.constructor);
 alert(arr.constructor);
 alert(date.constructor);

3.instanceof

判断一个对象是否是一个构造函数(类)的实例。注意此方法只能检测实例对象。返回布尔值

 var str=new String('abc');
 var num=new Number(100);
 var arr=new Array();
 var date=new Date();
 alert(str instanceof String);
 alert(num instanceof Number);
 alert(arr instanceof Array);
 alert(date instanceof Date);
 alert(str instanceof Object);

4.toString()

最牛逼的五星级方法,此方法功能强大,既可以进制转换,又可以转字符串,使用起来逼格级高

 console.log(Object.prototype.toString.call(5).slice(8,-1));
 console.log(Object.prototype.toString.call('abc').slice(8,-1));
 console.log(Object.prototype.toString.call(true).slice(8,-1));
 console.log(Object.prototype.toString.call(function(){}).slice(8,-1));
 console.log(Object.prototype.toString.call([]).slice(8,-1));
 console.log(Object.prototype.toString.call({}).slice(8,-1));
 console.log(Object.prototype.toString.call(/\d/g).slice(8,-1));
 console.log(Object.prototype.toString.call(new Date).slice(8,-1));
 console.log(Object.prototype.toString.call(null).slice(8,-1));
 console.log(Object.prototype.toString.call(undefined).slice(8,-1));
 console.log(Object.prototype.toString.call(Math).slice(8,-1));
 // Number
 // String
 // Boolean
 // Function
 // Array
 // Object
 // RegExp
 // Date
 // Null
 // Undefined
 // Math

相关推荐:

js数据类型检测的4种方法

Javascript isArray 数组类型检测函数_javascript技巧

JavaScript中对数据类型检测的方法总结

下载本文
显示全文
专题