JavaScript的隐式转换和toString valueof的调用情况

本文探讨JavaScript中的隐式类型转换规则,如在严格等于时的类型判断,以及如何进行number与string之间的转换。同时讲解了在对象转换为基本类型时,如何触发toString和valueOf方法,以及何时会抛出'cannot convert object to primitive value'的错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、隐式转换

console.log('35'-1);//34 减号转换为数值型计算
console.log('35'+2);//352 加号转换为字符串计算

console.log(0==false); //true
console.log("123"==123); //true
console.log(null==undefined);//true

=== 严格等于的时候,会首先判断类型是否相同
== 如果类型不同,会尝试类型转换和比较:
null == undefined相等
number == string 转number 1== “1.0”
boolean == ?转number 1==true
object == number|string 尝试对象转为基本类型 new String(‘hi’) == ‘hi’

当把基本类型尝试当成对象处理的时候,会生成一个内容的对象,当操作结束后,这个临时对象被销毁。

var a = "gmm";
console.log(a.x = 1); //1
console.log(a.x); //undefined
console.log(a.length); //3

二、toString valueof的调用情况

无论是一元加号+obj或者是二元的作为字符串拼接的+号,”result”+obj,都会尝试将对象转为字符串,如果valueOf存在,就会先找valueof,若果valueof返回的是基本类型的就会用这个值,如果是个对象就会找toString,如果toString是基本类型,就会用这个,如果是对象,就会报错,cannot convert object to primitive value

var obj = {
    a:1,
    toString: function(){
        return 12;
    },
    valueOf:function(){
        return {x:1};
    }
}
console.log(+obj);//12

var obj2 = {
    a:1,
    toString: function(){
        return 12;
    },
    valueOf:function(){
        return 3500;
    }
}
console.log(obj2-100);//3400
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值