Day.14 「基礎打穩了,就能走得更長久~」 —— JavaScript 基礎運算子
Day.14 「基礎打穩了,就能走得更長久~」 —— JavaScript 基礎運算子

學習任何東西,都要把基礎學的扎實,基礎穩了,遇到問題就能迎刃而解。
而學習程式語言的基礎就是數學邏輯,不用到很專精,只要有基礎數學邏輯,多寫多做就能鍛鍊出寫程式邏輯的金魚腦,基礎邏輯打穩了,任何程式語言都有相似的地方,會越學越快,然後發現根本是無底洞,沒有盡頭。
算數運算子
就如同我們國小上課一樣,算數就要先從 加、減、乘、除 的基礎開始教起,而運算先後順序就如同我們國中所學的,先乘除、後加減、有括號先算括號,這對聰明的你來說,實在是小 case!
| 運算符 | 說明 | 運算符 | 說明 | 
|---|---|---|---|
| + | 加法 | ++ | 自增 | 
| - | 減法 | -- | 自減 | 
| * | 乘法 | ** | 次方 | 
| / | 除法 | % | 餘數 | 
一元運算符
前面變數轉型那一篇有稍微提到使用 + 的一元運算符,來為變數轉型成數字型別。
而使用 - 的一元運算符,聰明的你,一定馬上就猜出來,是把型別變成數字型別的相反數。typeof 本身也是一元運算符,是用來判斷型別的。
字串串接
利用 + 運算符,可以進行字串串接,當 + 兩邊其中一邊為字串(string)型態時,JavaScript 會自動幫我們把兩邊的轉型成字串型態,並進行串接。
| 1 |  | 
自增 與 自減
++ 與 -- 可以對自己數字 增加 1 或 減少 1。
放在變數前後的位置很重要!
當運算符在前面時 ++a,當下為變數更改後的數值,想像已經先 +1。
當運算符在後面時 a++,當下為變數的原本數值,想像已經先賦值還來不及 +1。
| 1 |  | 
邏輯運算子
| 運算符 | 說明 | 判斷中斷規則 | 返回值 | 
|---|---|---|---|
| ! | 非(not) | 無 | 返回與原本布林值相反的值 | 
| && | 和(and) | 如果左側為 false,則不判斷右側值 | 如果左側為 false,返回左側的值,反之亦然 | 
| ∣∣ | 或(or) | 如果左側為 true,則不判斷右側值 | 如果左側為 false,返回右側的值,反之亦然 | 
藉由 JavaScript 任何型別都能轉換成布林值,會先轉換成布林值再進行邏輯判斷。
如果是使用 ! 返回的會是布林值,而 && 和 ∣∣ 返回的是原本的值。
| 1 |  | 
賦值運算子
| 運算符 | 說明 | 
|---|---|
| = | 最基本的賦值 | 
| += | a = a + 2與a += 2一樣 | 
| -= | a = a - 2與a -= 2一樣 | 
| *= | a = a * 2與a *= 2一樣 | 
| /= | a = a / 2與a /= 2一樣 | 
| %= | a = a % 2與a %= 2一樣 | 
最基礎的 = 就是賦值語句,把右側的值,賦值給左側的變數。
而 = 左側添加算術運算子,能有效把原本比較長的運算式簡化。
比較運算子
| 運算符 | 說明 | 
|---|---|
| > | 是否大於 | 
| < | 是否小於 | 
| >= | 是否大於等於 | 
| <= | 是否小於等於 | 
| == | 是否相等 | 
| != | 是否不相等 | 
| === | 是否全等 | 
| !== | 是否不全等 | 
用來進行比較的運算子,就跟數學課的比大小一樣。
比較運算子會對兩側值進行比對,返回的會是布林值。
| 1 |  | 
== 相等 與 === 全等 的差別
簡單來說,== 比較時 JavaScript 會自動幫你轉型進行比對,而 === 則是進行嚴格比對,不會自動轉型。
| 1 |  | 
比較運算子中的特例! NaN
在所有型別中,數字型別的 NaN 非常特別,NaN 不管跟誰比對,都是回傳 false,包括他跟自己比對也是。
| 1 |  | 
總結
一開始我也以為邏輯運算子返回的都是布林值,但實際返回的並不一定是布林值,因為這個特性,讓我們在撰寫 JavaScript 會更加彈性好運用來取得我們所想要的值。
我們現在已學會了基本的宣告變數與基礎型別,也學會了基礎的運算子,接著我們就能利用目前所學的東西,來學習如何讓程式語言幫我進行條件判斷!下一個章節就來介紹條件判斷式!