JS中,在运算符下valueOf与toString的关系

先说结论:运算操作(+|-|*|÷)时,对象的valueOf属性会先被调用,默认的valueOf属性会隐性地调用toString方法。

var a = {
        toString: function() {
                    console.log("in a.toString");
                    return "|_a->toString_|";
                },
                valueOf: function() {  
                    console.log("in a.valueOf");
                        return "|_a->valueOf_|";  
                    }
           };
alert(a);
//控制台->  in a.toString
//弹窗->  |_a->toString_|

结论1:alert方法只是单独直接调用toString方法;

var a = {
        toString: function() {
                    console.log("in a.toString");
                    return "|_a->toString_|";
                },
                valueOf: function() {  
                    console.log("in a.valueOf");
                        return "|_a->valueOf_|";  
                    }
           };
""+a;
//控制台->  in a.valueOf
""-a;
//控制台->  in a.valueOf
""*a;
//控制台->  in a.valueOf
""/a;
//控制台->  in a.valueOf

结论2:运算符会调用对象的valueOf方法;

var a = {
 ///      toString: function() {
 //                console.log("in a.toString");
 //                   return "|_a->toString_|";
 //               },
          valueOf: function() {  
                      console.log("in a.valueOf");
                      return "|_a->valueOf_|";  
                  }
           };
""+a;
//控制台->  in b.valueOf
""-a;
//控制台->  in b.valueOf
""*a;
//控制台->  in b.valueOf
""/a;
//控制台->  in b.valueOf

结论3:操作符默认不会调用toString方法;

var a = {
        toString: function() {
                    console.log("in a.toString");
                    return "|_a->toString_|";
                },
///              valueOf: function() {  
//                  console.log("in a.valueOf");
//                  return "|_a->valueOf_|";  
//                  }
           };
""+a;
//控制台->  in b.toString
""-a;
//控制台->  in b.toString
""*a;
//控制台->  in b.toString
""/a;
//控制台->  in b.toString

结论4:默认的valueOf会调用toString方法;

总结:
alert():只调用toString
运算符:只调用valueOf
valueOf(默认):会调用valueOf

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值