目录

  • 引言
  • ++和--在数学运算中的计算规则
  • ++和--在变量引用时的计算规则
  • ++和--的数据转换应用

引言

  对于接触JS时间不长的前端来说,刚开始要实现诸如轮播图,选项卡等小模块时,肯定会用到index索引来实现。而这其中很大一部分又会使用++(自加)、--(自减),所以清楚的知道++(自加)、--(自减)的计算模式,可以在运用时减少错误。本文将从数学运算、变量引用、数据转换3个方面,对++(自加)、--(自减)进行一个详细的说明,力求达到一个在通读全文后,明确++(自加)、--(自减)应用方式的效果。

一、++和--在数学运算中的计算规则

老规矩,先上代码

     let a = 1,
b = 1;
let num1 = a++ + b++, //num1执行前a=1,b=1,num1执行后a=2,b=2
num2 = a++ + ++b, //num2执行前a=2,b=2,num2执行完后a=3,b=3
num3 = ++a + b++, //num3执行前a=3,b=3,num3执行完后a=4,b=4
num4 = ++a + ++b; //num4执行前a=4,b=4,num4执行完后a=5,b=5
console.log(num1); //结果为2,步骤分解: a + b(1 + 1)=> a++(2) => b++(2) => a=2,b=2;
console.log(num2);  //结果为5,步骤分解: a + (++b)(2 + 3) => a++(3) => a=3,b=3;
console.log(num3);  //结果为7,步骤分解: (++a) + b(4 + 3) => b++(4) => a=4,b=4;
console.log(num4);  //结果为10,步骤分解: (++a) + (++b)(5 + 5) => a=5,b=5;

  通过以上代码,可以总结出++和--在数学运算出的计算规则如下(加减乘除没区别):

    1)当++、--写在变量前时,数学计算时,引用的是++、--未执行的变量值;

    2)当++、--写在变量后时,数学计算时,引用的是++、--执行后的变量值;

  

  通过以上的理解,就不难看出,num1得到的求和结果实际上就是a + b,而num2实际上是a + (++b),num3是(++a) + b,num4是(++a) + (++b),但是求和归求和,++、--只是没在求和结果中执行,实际上变量的++、--都是执行了的,这一点要明确。

二、++和--在变量引用时的计算规则

上代码

     let num1 = 0,
num2 = 0;
let arr = [0, 1, 2, 3, 4, 5, 6];
console.log(arr[num1++]); // 0 num1=1
console.log(arr[++num2]) // 1 num2=1

  通过以上代码,不难看出,当在变量引用时执行++、--,与数学运算有相似的规律。总结起来就是一句话——++、--在变量前,引用++、--执行后的变量值;++、--在变量后,引用当前变量值(即执行++、--前的值)。

三、++和--的数据转换应用

上代码

     let a = true;
let b = false;
let c = "a";
console.log(++a); //
console.log(b++); //
console.log(c++); //NaN

  一句话总结——对非Number类型的数据,应用++、--,相当于执行了Number()方法。如果转换后是number类型,则按上边的规则执行++和--,如果转换后不是number类型,则不执行++和--。输出NaN。不能直接进行类似++true的操作,必须通过声明变量值为true或false,然后再++、--。

javascript精雕细琢(二):++、--那点事的更多相关文章

  1. 学习javascript数据结构(二)——链表

    前言 人生总是直向前行走,从不留下什么. 原文地址:学习javascript数据结构(二)--链表 博主博客地址:Damonare的个人博客 正文 链表简介 上一篇博客-学习javascript数据结 ...

  2. 初探JavaScript(二)——JS如何动态操控HTML

    除去五一三天,我已经和<JavaScript Dom编程艺术>磨合了六天,第一印象很好.慢慢的,我发现这是一块排骨,除了肉还有骨头.遇到不解的地方就会多看几遍,实在不懂的先跳过,毕竟,初次 ...

  3. 从头开始学JavaScript (十二)——Array类型

    原文:从头开始学JavaScript (十二)--Array类型 一.数组的创建 注:ECMAscript数组的每一项都可以保存任何类型的数据 1.1Array构造函数 var colors = ne ...

  4. 使用JavaScript生成二维码教程-附qrcodejs中文文档

    使用javascript生成二维码 依赖jquery 需要使用到的库 https://github.com/davidshimjs/qrcodejs DIV <div id="qrco ...

  5. 同事问如何判断同花顺,我用javascript的二维数组写了个简易demo

    有个前同事在群里问如何判断是否为同花顺我用javascript的二维数组写了个简易demo. <!DOCTYPE html> <html> <body> <s ...

  6. 2、JavaScript 基础二 (从零学习JavaScript)

     11.强制转换 强制转换主要指使用Number.String和Boolean三个构造函数,手动将各种类型的值,转换成数字.字符串或者布尔值. 1>Number强制转换 参数为原始类型值的转换规 ...

  7. Javascript面向对象二

    Javascript面向对象二 可以通过指定原型属性来对所有的对象指定属性, Object.prototype.name="zhangsan"; Object.prototype. ...

  8. QrCode C#生成二维码 及JavaScript生成二维码

    一 C#的二维码    示例: class Program { static void Main(string[] args) { QrEncoder qrEncoder = new QrEncode ...

  9. JavaScript模块化开发的那些事

    模块化开发在编程开发中是一个非常重要的概念,一个优秀的模块化项目的后期维护成本可以大大降低.本文主要介绍了JavaScript模块化开发的那些事,文中通过一个小故事比较直观地阐述了模块化开发的过程. ...

  10. 一篇文章图文并茂地带你轻松学完 JavaScript 设计模式(二)

    JavaScript 设计模式(二) 本篇文章是 JavaScript 设计模式的第二篇文章,如果没有看过我上篇文章的读者,可以先看完 上篇文章 后再看这篇文章,当然两篇文章并没有过多的依赖性. 5. ...

随机推荐

  1. DPDK L3fwd 源码阅读

    代码部分 整个L3fwd有三千多行代码,但总体思想就是在L2fwd的基础上,增加网络层的根据 IP 地址进行路由查找的内容. main.c 文件 int main(int argc, char **a ...

  2. 《TCP/IP 详解 卷1:协议》第 10 章:用户数据报协议

    引言 UDP 稍微扩展了IP协议,使得包可以在进程间传送,而不仅仅是在主机件.--<CSAPP> IP 数据报是指 IP 层端到端的传输单元.分组(packet)是 IP 层和链路层的传输 ...

  3. 关于react 官方脚手架使用出现的问题

    首先按照官网说明,一路的安装下来,很顺利,然后开始运行吧,提示个错误,缺少index.js 文件  原来是默认给出的文件是App.js 如何更改呢 找到react-script模块文件夹config下 ...

  4. 作死实验,删除libc.so.6

    参考https://www.cnblogs.com/fjping0606/p/4551475.html https://www.cnblogs.com/weijing24/p/5890031.html ...

  5. 性能分析_linux服务器CPU_Load Average

    CPU度量Load Average 1.  概念介绍 1.1  Linux系统进程状态 在linux中,process有以下状态: runnable (就绪状态):blocked waiting fo ...

  6. HBase 架构与工作原理2 - HBase 组件

    本文系转载,如有侵权,请联系我:likui0913@gmail.com 一.HBase 组件概览 Master-Slave 模式: HBase 体系结构遵循传统的 master-slave 模式,由一 ...

  7. mysql 时间格式化参数表笔记

    DATE_FORMAT() 函数用于以不同的格式显示日期/时间数据. 语法: DATE_FORMAT(date,format) 实例: DATE_FORMAT(NOW(),'%b %d %Y %h:% ...

  8. firewall和iptables

    防火墙有这三种方式,firewalld.iptables.ebtables,现在的centOS7使用的是firewalld. 下面是一些总结: 查看当前firewalld的状态 firewall-cm ...

  9. 先验算法(Apriori algorithm) - 机器学习算法

    Apriori is an algorithm for frequent item set mining and association rule learning over transactiona ...

  10. myeclipse8.6 注册码

    MyEclipse8.6 注册码 别处找的均是8.6版本,可以使用到2014年一:MyEclipse Standard Edition: zhucemLR7ZL-655954-695876566190 ...