本文提到的对象到字符串和数字的转换规则只适用于本地对象。什么是本地对象呢?本地对象也叫做内置对象,也就是JS标准规范定义的对象或类。比如Array
, object
, function
, data
, global
。还有一类对象即宿主对象,顾名思义,宿主,宿主,就要有一个寄生的对象和环境,在JS中宿主对象都是寄生在浏览器中的。在浏览器中才存在的对象。比如event
,BOM 和DOM对象皆是。
本地对象都继承了俩个转换方法,toString()
与valueOf()
。
对象到字符串的转换过程
toString()方法用在对象上面,比如function
, array
,object
,返回的值都差不多,都是返回这个对象的源码。但是是以字符串表示的形式。例如:
var a = [1,2]; var b = a.toString(); console.log(b); typeof b; //1,2 //"string"
函数类返回的结果也类似,可以从下面的实例中看出来:
var fun = function() { return "hello world!"; } var obj = fun.toString(); console.log(obj); typeof obj; //function () { return "hello world!"; } //"string"
valueOf存在任意原始值,它就默认将对象转换为表示它的原始值。如果是复合值呢,和toString方法一样,即返回本身。但是还是和toString()方法有区别,tostring返回的是以字符串形式表示,valueOf()返回的是以对象的形式表示:
var arr = [true, "string"]; var obj = arr.valueOf(); console.log(obj); typeof obj; // [true, "string"] //"object"
var a = {}; a.toString(); a.valueOf(); //"[object Object]" //Object {}
对象是空对象时,不管是toString方法或者valueof返回的形式有点让人很迷惑,toString()看上去更上一个对象的表示,不过对他们用typeof以查看就清楚了然了,toString返回的确是一个字符串表示的对象形式,而valueof返回的才是真正的对象。
var b = a.toString(); var c = a.valueOf(); console.log(typeof b); //string console.log( typeof c) //object
如果让对象和进行比较呢 ?又会发生什么,比如:
var a = {}; var c = a.toString(); console.log(a==c); // true
这里在进行比较的时候,我们可以看到,a在执行了toString方法之后,就是一个字符串,但是在比较的时候,既字符串和对象比较的时候,返回的是true,a是一个对象,在比较时发生了隐式的类型转换。遵循对象到字符串先调用tostring的方法。那如果我们手动把a用valueOf转换一下呢。 比如:
var d = a.valueOf(); console.log(d==c); // true
console.log(c); // [object Object] console.log(d); // Object {} console.log(d===c);
情况还是和上面是一样的,但是如果不想他们进行自动转换就要使用严格相等了,这样的情况下,我们可以很清楚的看到返回的false。
console.log(d===c); // false
数组的在执行了之上的过程也是一样的。在此就不赘述了。
总结
对象到字符串的转换
首先调用toString方法,只有当toString不返回一个原始值的时候,才会调用valueOf()。toString方法但是基本上所有对象都返回字符串。所以对象到字符串形式的转换基本都是使用toString方法。
俩个方法都不返回原始值时,会抛出错误。
对象到数字的转换过程
首先调用的valueOf(),如果返回原始值,将原始值转换为数字并返回。valueOf,基本上所有的 对象返回的都是对象,虽然先使用valueOf,但是实际上也是使用的toString的方法。
我们明白了这些规则有什么用?比如为什么空数组转换为数字是?单个数组的元素为数字的同样转换为一个数字
,比如:
var rr = [], dd = 2; console.log(rr < dd); // true
为什么返回true,因为在执行比较的时候,是对象和数字的比较,需要先把对象转换数字,先把rr对象进行隐式的类型转换,调用valueOf方法,但是返回的是一个对象,所以调用toString,toString方法返回的是一个空的字符串,空的字符串直接转换为0;JS引擎在内部运算的时候,我的理解是隐形的执行了这些元算;
var gg = rr.toString(); Number(gg); //0
运算符,及其他比较大小的运算符时,都会做对象到原始值的转换,对象到原始值的转换基本都是对象到数字的转换,但是要除去日期对象的特殊情形,日期对象 到原始值转换规则为对象到字符串模式。本篇文章是对《JS权威指南》第三章对象到原始值的转换的一个读书笔记。如果有什么的描述的不对,敬请指正!