带你读书之“红宝书”:第三章 语法基础(中)之 3.5操作符①

「这是我参与2022首次更文挑战的第13天,活动详情查看:2022首次更文挑战

写在前头

大多数小伙伴看技术书籍都会用“啃”来描述读书的直观感受,当然我也是一个前端小白,白的透明那种,但是我在读技术书籍感觉到“啃”的时候,我希望把我啃红宝书第四版的过程的想法,总结带给大家,以供后来者能够更快上手。

注: 本文由于作者水平原因,如有错误之处,恳请大家指正,另外随着学习的深入,体会的加深,我会不断回来更新,修改这类文章。

思维导图

3.语法基础(1).png

脉络 3.5操作符

这小节就是介绍了3.5操作符

3.5操作符

image.png

简述

操作符,顾名思义就是用来操作数据值的一种符号。书上的解释也很详细,还涉及了使用方法转换对象,以便操作。

3.5.1一元操作符

image.png

1. 递增/递减操作符

概念:几元操作符就意味着可以操作几个数值。

  • 前缀

  • 后缀

    前缀,后缀递增递减都和c语言一样,前缀就先加减后运算,后缀就先运算后加减。

  • 字符串,布尔值

    先转换后操作。

    有效数值字符串->数值, 无效数值字符串-> NaN,

    布尔值: false -> 0 , true -> 1

  • 浮点数

    浮点数也是数值,直接操作。

  • 对象

    操作符不可以直接操作对象,使用对象自带的valueOf()方法将其转换为可以操作的值,如果是NaN,则使用toString()继续转换。

2. 正/负操作符

  • 数值

    和小学学的正负数前面的正负号一个道理。

  • 非数值(数据类型转换)

    在操作符面前非数值的一般都先进行数据类型的转换,然后再操作。

3.5.2. 加性操作符

image.png

说白了就是加减符号,但是又不单单是我们小学那种简单的加减符号。

  1. 加法操作符
  • 操作数都是数值

当都是数值的时候,小学生都可以做了,直接2数相加求解。
但是遇到Infinity,NaN就得小心。

 <script>
        console.log(NaN + 1); //    NaN
        console.log(Infinity + -Infinity); // NaN
        console.log(Infinity + 1); // Infinity
        console.log(-Infinity + -Infinity); // -Infinity
        console.log(+0 + +0); // 0
        console.log(-0 + -0); // 
        console.log(+0 + -0); //
    </script>
  • 操作数中都没有字符串和对象

使用Number()转换,再执行上述规则。

  • 有一个操作数是字符串或者对象

使用String()转换,再操作拼接。

  • 常犯的一个错误

忽略加法操作中涉及的数据类型。从前到后依次加

 <script>
     let num1 = 1;
     let num2 = 2;
       console.log('hello'+ num1 + num2); // hello12
    </script>

注意这里hello和num1加的时候,num1被转换为字符型变成hello1,然后这个新的‘hello1’和num2相加又会让2个都转化为字符串。num2又转换为字符串,所以最终结果不是“hello3”是“hello12”。

  1. 减法操作符
  • 操作数都是数值

和上面加法一样,但是得记住一些特别的。

   <script>
        console.log(2 - 1); //       1              
        console.log(NaN - 1); //    NaN
        console.log(1 - NaN); //  NaN
        console.log(Infinity - Infinity); //   NaN
        console.log(-Infinity - (-Infinity)); //    NaN
        console.log(-Infinity - -Infinity); //    NaN
        console.log(+0 - +0); //    0
        console.log(+0 - (-0)); //    0
        console.log(-0 - (-0)); //   0
    </script>
  • 任一操作数不是数值

同上,使用Number()方法转换在操作。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值