當前位置: 首頁 / 技術分享 / 正文
好程序員web前端教程分享初學者搞懂i++和++i

2019-12-06

HTML5 好程序員 HTML5培訓 web前端培訓

好程序員web前端培訓分享初學者搞懂i++++i

剛學習前端的同學,在學到++運算符的時候,都是一臉的懵

var k = 10;

console.log(k++ + ++k + k++)  //34

var i = 10;

console.log(++i + i++ + ++i)  //35

console.log(i++ + ++i + i++)  //43

***way???為什么?為什么?為什么?***

 

下面我們一步一步的來看:

 

>1 var i = 10;

>

>2 i++; //等價于i=i+1

console.log(i); //11

 

###++可以與輸出語句寫在一起,++寫在變量前和寫在變量后不是一個意思

 

>i++ : 先用a的原值,然后i1

>++i :先給a1,然后用i的新值

 

```

1 var i = 10;

console.log(i++); //10 ,先引用原值,然后加1

 

等價于:

 

 var i= 10;

2 console.log(i);   //先輸出i

3 i++;              //然后fi

```

 區別于:

```

1 var i = 10;

2 console.log(++i);  //11 , 這次是先加1,然后輸出

```

 

++有點意思的玩法:

```

1 var i = 8;

 

2 console.log(4 + i++);   //12  , 先使用原來的a的值,就是4+8,輸出12.然后a1

 

3 console.log(i);     //9

 

4 console.log(++i % 5);   //0  , 先把i1,然后使用i10%5=0

 

5 console.log(i);     //10

```

 

```

1 var a = 1;          //a的值1

 

2 var b = a++;       //b的值是1a的值是++寫在后面,是先用再加

 

3 a += ++b;           //先把b1b就是2了,a原來是2,加上2,就是4

 

4 console.log(a);    //4

 

console.log(b);    //2

```

```

1 var a = 3;                //a的值是3

 

2 console.log(a++ + a++);  //計算從左到右的,所以第一次a++時用的是3a變為4

 

3                            //第二次遇見a++的時候,a用的是4,變為5

 

4                            //3 + 4 所以輸出7

 

console.log(a);          //輸出5

```

 

```

1 var a = 3;

 

2 console.log(a++ + ++a);  //8

 

console.log(a);           //5

```

 

總結:

其實++運算符非常的簡單,只要你記住一句口訣:++在前下自加后運算;++在后先運算后自加;然后在細心點就好了。

 

好程序員開班動態

More+
  • HTML5大前端 <高端班>

    開班時間:2020-02-17(北京)

    預約報名

    開班時間:2020-03-02(深圳)

    預約報名
  • 大數據+人工智能 <好程序員嚴選班>

    開班時間:2019-12-23(北京)

    開班盛況
  • 大數據+人工智能 <好程序員班>

    開班時間:2020-02-24(杭州)

    預約報名

    開班時間:2020-02-17(北京)

    預約報名
  • JavaEE分布式開發 <高端班>

    開班時間:2020-03-09(北京)

    預約報名
  • Python全棧+人工智能 <高端班>

    開班時間:2019-07-22(北京)

    開班盛況
  • 云計算開發 <高端班>

    開班時間:2020-02-24(北京)

    預約報名
在線咨詢
免費試聽
入學教程
立即報名

Copyright 2007-2019 北京千鋒互聯科技有限公司 .All Right 京ICP備12003911號-5 京公安網11010802011455號

日日看福利,日日看在线视频