自定义 `toString()` 与 `valueOf()` 方法在原型链中的覆盖

好的,各位观众老爷们,欢迎来到“原型链历险记”!今天咱们要聊点刺激的,聊聊 toString() 和 valueOf() 这俩哥们儿,以及它们在原型链里“改头换面”的故事。准备好了吗?系好安全带,我们要起飞咯!🚀 第一幕:初识 toString() 和 valueOf(),这俩是啥玩意儿? 在开始之前,咱们得先搞清楚,toString() 和 valueOf() 到底是个啥。简单来说,它们是 JavaScript 对象自带的两个方法,就像每个公民都有自己的身份证一样。 toString(): 顾名思义,它的主要任务就是把一个对象“变”成字符串。当你试图把一个对象用字符串的方式展示出来时,JavaScript 就会自动调用这个方法。比如,你想把一个数字显示在网页上,或者用 console.log() 打印出来,toString() 就默默地在背后工作。 就像灰姑娘变身一样,把原本平平无奇的对象,变成闪闪发光的字符串!✨ valueOf(): 这个家伙比较低调,它的作用是返回对象的原始值。这个原始值通常是数字、字符串或者布尔值。在某些需要对对象进行运算的场合(比如加减乘除),JavaScr …