js精确判断数据类型为何用Object.prototype.toString.call()而不是Object.prototype.toString()

有何区别,为何一定要通过call。

我们知道call是用来改变函数作用域的,Object.prototype.toString.call在这儿也是用来改变作用域的。

Object.prototype.toString()  在toString方法被调用时,会执行下面的操作步骤(参考):

1. 获取this对象的[[Class]]属性的值。

2. 计算出三个字符串"[object ", 第一步的操作结果Result(1), 以及 "]"连接后的新字符串。

3. 返回第二步的操作结果Result(2)。

[[Class]]是一个内部属性,所有的对象(原生对象和宿主对象)都拥有该属性.在规范中,[[Class]]是这么定义的: 内部属性 描述 [[Class]] 一个字符串值,表明了该对象的类型。

其过程简单说来就是:1、获取对象的类名(对象类型)。2、然后将[object、获取的类名、]组合并返回。

需用用call的关键地方就在第1步,获取的是this对象,不加call改变作用域时this指向的是window啊!

还有一定,为何一定要用原型链最顶层的Object.prototype,而不是直接用需要获取数据类型对象的呢,因为在原型链上找toString方法时,还没到找到Object的

时候,就已经找到了其本身对象的toString方法了,而这个方法改写了Object的了。

时间: 2024-10-14 18:55:01

js精确判断数据类型为何用Object.prototype.toString.call()而不是Object.prototype.toString()的相关文章

【JS】----判断数据类型的方法

对js中不同数据的布尔值类型总结:false:空字符串:null:undefined:0:NaN.true:除了上面的false的情况其他都为true: 如下: var o = { 'name':'lee' }; var a = ['reg','blue']; function checkBoolean(a){ if(a){ return true; }else{ return false; } } console.log(checkBoolean('')); //false console.l

js中判断数据类型的方法 typeof

<input type="text" onblur="demo(this)"/><br/> <input type="number" onblur="demo(this)" /><br/> <script> function demo(obj){ alert(obj.value+" 数据类型是 "+typeof(obj.value)); alert

函数作为返回值输出 判断数据类型

1判断数据类型 var gettype = function(type){ return function(obj){ return Object.prototype.toString.call(obj) == '[object '+ type +']'; } } var isString = gettype('String'); console.log(isString('123'));//true 应用循环批量注册isType函数 var Type={}; for(var i=0,type;

利用Object.prototype.toString.call(obj)判断数据类型

1.typeof判断数据类型 typeof可以用来判断基本数据类型,对于Array.Error.RegExp.Number.Function只能判断为object 2.使用Object.prototype.toString.call(obj)判断数据类型 var a=new Number(12); var toString=Object.prototype.toString; console.log(toString.call(a));//[object Number] console.log(

判断数据类型instance of type of object.prototype.tostring 区别

typeof typeof 是一个操作符,其右侧跟一个一元表达式,并返回这个表达式的数据类型. 返回的结果用该类型的字符串(全小写字母)形式表示,包括以下 6 种: number.boolean.string.object.undefined.symbal .function. typeof 对于对象,除了函数都会显示 object 对于 null 来说,虽然它是基本类型,但是会显示 object,这是一个存在很久了的 Bug instance of instanceof 是用来判断 A 是否为

如何判断js中的数据类型?

js六大数据类型:number.string.object.Boolean.null.undefined string: 由单引号或双引号来说明,如"string" number: 什么整数啊浮点数啊都叫数字,你懂的~ Boolean:  就是true和false啦 undefined: 未定义,就是你创建一个变量后却没给它赋值~ null:  故名思久,null就是没有,什么也不表示 object: 这个我也很难解释的说.就是除了上面五种之外的类型 如何判断js中的数据类型:type

JavaScript的数据类型都有什么? JavaScript中 toStirng() 与 Object.prototype.toString().call()

JavaScript的数据类型都有什么? (via  BAT互联网公司2014前端笔试面试题:JavaScript篇  http://www.sxt.cn/u/756/blog/4508) 基本数据类型:String,boolean,Number,Undefined, Null 引用数据类型: Object(Array,Date,RegExp,Function) 疑问:这些基本的数据类型的值都是常量,而常量是没有方法的,为什么能够调用方法呢?答案是这样的,五种基本类型除了null.undefin

如何判断js中的数据类型

如何判断js中的数据类型:typeof.instanceof. constructor. prototype方法比较 如何判断js中的类型呢,先举几个例子: var a = "iamstring."; var b = 222; var c= [1,2,3]; var d = new Date(); var e = function(){alert(111);}; var f = function(){this.name="22";}; 最常见的判断方法:typeof

[转]如何判断js中的数据类型

原文地址:http://blog.sina.com.cn/s/blog_51048da70101grz6.html 如何判断js中的数据类型:typeof.instanceof. constructor. prototype方法比较 如何判断js中的类型呢,先举几个例子: var a = "iamstring."; var b = 222; var c= [1,2,3]; var d = new Date(); var e = function(){alert(111);}; var