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

判断变量的数据类型

时间:2019-11-21 11:51:11      阅读:73      评论:0      收藏:0      [点我收藏+]

标签:fun   ati   const   冲突   参数   style   构造函数   color   地方   

Object.prototype.toString.call()

判断变量类型的所有方法中,该方法可以说是判断的最完全的方法,所有的数据类型都可以判断,在使用Object.prototype.toString.call()方法判断变量类型时,需要判断的变量会放在小括号内

var str = "abc";
Object.prototype.toString.call(str); // [object String]

打印出来的字符串中第一个是call方法所在的原型实例是object,第二个就是我我们进行判断的变量的数据类型,这个方法可以判断任何的数据类型

var num= 123;
Object.prototype.toString.call(num); // [object Number]
var bool= true;
Object.prototype.toString.call(bool); // [object Boolean]
var n = null;
Object.prototype.toString.call(n); // [object Null]
var un = undefined;
Object.prototype.toString.call(un); // [object Undefined]
var func = function(){};
Object.prototype.toString.call(func); // [object Function]
var obj= {};
Object.prototype.toString.call(obj); // [object Object]

以及ES6的新变量Symbol也可以进行判断

var syb= Symbol("abc");
console.log(Object.prototype.toString.call(syb)); // [object Symbol]

typeof

typeof方法可以说是我们接触的比较早的判断变量的方法了,这个方法可以判断基本数据类型

typeof "abc" // "string"
typeof 123 // "number"
typeof true // "boolean"
typeof undefined// "undefined"

但是在判断null类型时,与其他判断结果产生了冲突

typeof null // object
typeof [] // object
typeof {} // object

结果为"function",也有冲突

typeof function(){} // "function"
typeof Symbol // "function"

Symbol虽然被称为ES6的新变量,但它本身是一个构造函数,我们在声明变量的时候可以感受到

var syb = Symbol("abc")

Symbol后面加上了一个小括号,后面带小括号只有在调用函数的时候呀才回出现,而且这个地方判断变量还有一个新的情况

typeof syb // "symbol"

当Symbol加入了参数时,typeof的结果就变成了"symbol"

constructor

通过变量的构造函数也可以得到变量的类型是什么,但是不能判断null和undefined,因为这两个数据类型不能通过实例化得到,所以不存在构造函数

[].constructor // ƒ Array() { [native code] }
{}.constructor // ƒ Object() { [native code] }
(123).constructor // ƒ Number() { [native code] }
"abc".constructor // ƒ String() { [native code] }
true.constructor // ƒ Boolean() { [native code] }
function(){}.constructor // ƒ Function() { [native code] }
Symbol.constructor // ƒ Function() { [native code] }
Symbol("abc").constructor // ƒ Symbol() { [native code] }

这里也要注意function(){}和Symbol的构造函数也都是f Function(){[native code]}

function(){}.constructor // ƒ Function() { [native code] }
Symbol.constructor // ƒ Function() { [native code] }

判断变量的数据类型

标签:fun   ati   const   冲突   参数   style   构造函数   color   地方   

原文地址:https://www.cnblogs.com/Function-cnblogs/p/11904234.html

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