码迷,mamicode.com
首页 > 其他好文 > 详细

检测数据类型的6中方法

时间:2018-10-23 16:24:26      阅读:120      评论:0      收藏:0      [点我收藏+]

标签:原型链   最好   nbsp   各类   xxx   好的   输出   span   括号   

第一种:typeof 可以检测一些基本的数据类型
语法:typeof 后面加不加括号都是可以用的
注意:正则、{}、[]、null输出结果为object
所以这个方法并不是很好

例子:

console.log(typeof /\d/);//object
console.log(typeof {});//object
console.log(typeof []);//object
console.log(typeof (null));//object
console.log(typeof 123);//number
console.log(typeof true);//boolean
console.log(typeof function () {});//function
console.log(typeof (undefined));//undefined

 

第二种:instanceof 检测当前实例是否隶属于某各类。
双目运算符 a instanceof b ,判断a的构造器是否为b,返回值为布尔值

例子:

1 function fn() {}
2 let f = new fn;
3 console.log(f instanceof fn);//true
4 console.log(f instanceof Object);//true
5 let arr = [1,2,3,4];
6 console.log(arr instanceof Array);//true

 

第三种:constructor 构造函数
语法:实例.constructor

例子:

1 function fn() {}
2 let f = new fn;
3 console.log(f.constructor.name);//fn
4 console.log(fn.constructor);//Function(){}
5 console.log(Function.constructor);//Function(){}

 

第四种:hasOwnporperty 检测当前属性是否为对象的私有属性
语法: obj.hasOwnporperty("属性名/K值")

例子:

let obj = {
name:"xx"
};
console.log(obj.hasOwnProperty(‘name‘));//true
console.log(obj.hasOwnProperty(‘xxxx‘));//false

 

第五种:is Array 判断是否为数组
例子:

console.log(Array.isArray([]));//true
console.log(Array.isArray(new Array()));//true

 

第六种:Object.portotype.toString (最好的
语法:Object.prototype.toString.call([value])
获取Object.portotype上的toString方法,让方法的this变为需要检测的数据类型值,并且让这个方法执行


在Number、String、Boolean、Array、Function、RegExp...这些类的原型上都有一个toString方法:这个方法就是把本身的值转化为字符串

(12).toString()//‘12‘
(true).toString()//‘true‘
[12,23].toString()//‘12.23‘

...

在Object这个类的原型上也有一个方法toString,但是这个方法并不是把值转换成字符串,而是`返回当前值得所属类详细信息,固定结构:‘[object 所属的类]‘`

 

1 var obj ={name:‘珠峰‘}
2 obj.toString()//[object Object]

 

调取的正是Object.prototype.toString方法


obj.toString()
 首先执行Object.prototype.tostring方法
 这个方法中的this就是我们操作的数据值obj
 =>总结:Object.prototype.toString执行的时候返回当前方法中的this的所属类信息

 也就是,我想知道谁的所属类信息,我们就把这个toString方法执行,并且让this变为我们检测的这个数据值,那么方法返回的结果就是当前检测这个值得所属类信息
 Object.prototype.toString()
 ({}).toString.call([value])

Object.prototype.toString.call(12)//[boject Number]

Object.prototype.toString.call(true)//[boject Boolean]

......

"[object Number]"
"[object String]"
"[object Object]"
"[object Function]"
"[object Undefined]"
"[object Null]"
"[object RegExp]"
"[object Boolean]"

使用toString检测数据类型,不管你是啥值,我们都可以正常检测出需要的结果(这个方法检测是`万能`的)

话外:
1.Math是个对象,不是类。类才有prototype(原型)。`也就是说类都有原型:prototype,对象都有原型链:__proto__,函数既是类,也是对象,也是函数。`
2.如何把对象转换成字符串?

 对象下的toString方法是检测数据类型的,而不是用来转化成字符串的,这时可以用JSON的方法来转化

1 let obj={name:‘朱军林‘}
2 obj.toString()//=>"[object Object]"
3 
4 
5 JSON.stringify({name:‘朱军林‘})
6 "{"name":"朱军林"}"

 

检测数据类型的6中方法

标签:原型链   最好   nbsp   各类   xxx   好的   输出   span   括号   

原文地址:https://www.cnblogs.com/MrZhujl/p/9837152.html

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