|
|
|
|
# JavaScript 入門 - 做出決定
|
|
|
|
|
|
|
|
|
|
![JavaScript 入門 - 做出決定](/sketchnotes/webdev101-js-decisions.png)
|
|
|
|
|
> 由 [Tomomi Imura](https://twitter.com/girlie_mac) 繪製
|
|
|
|
|
|
|
|
|
|
## 課前測驗
|
|
|
|
|
[課前測驗](https://happy-mud-02d95f10f.azurestaticapps.net/quiz/11?loc=zh_tw)
|
|
|
|
|
|
|
|
|
|
為程式碼做決定與控制順序以提高其重複利用性與豐富性。這堂課程提供 JavaScript 的資料流控制語法與布林資料型的重點。
|
|
|
|
|
|
|
|
|
|
[![做出決定](https://img.youtube.com/vi/SxTp8j-fMMY/0.jpg)](https://youtube.com/watch?v=SxTp8j-fMMY "做出決定")
|
|
|
|
|
|
|
|
|
|
> 點擊上方圖片以觀賞關於程式做決定的影片。
|
|
|
|
|
|
|
|
|
|
## 回顧布林資料型
|
|
|
|
|
|
|
|
|
|
布林只能有兩種數值: `true` 或 `false`。 布林幫助程式碼間在特定的條件下做出決定。
|
|
|
|
|
|
|
|
|
|
設定布林值的方式如下:
|
|
|
|
|
|
|
|
|
|
`let myTrueBool = true`
|
|
|
|
|
`let myFalseBool = false`
|
|
|
|
|
|
|
|
|
|
✅ 布林的命名來源為一位英格蘭數學家、哲學家暨邏輯學家喬治·布爾 George Boole (1815–1864)。
|
|
|
|
|
|
|
|
|
|
## 關係運算子與布林
|
|
|
|
|
|
|
|
|
|
運算子會被使用在執行比較上,並回傳布林值。以下是常用的運算子列表。
|
|
|
|
|
|
|
|
|
|
| 符號 | 描述 | 舉例 |
|
|
|
|
|
| ----- | -------------------------------------------------------------------------- | ------------------ |
|
|
|
|
|
| `<` | **小於**: 比較兩數,當左數小於右數時,回傳 `true`。 | `5 < 6 // true` |
|
|
|
|
|
| `<=` | **小於等於**: 比較兩數,當左數小於右數或左數等於右數時,回傳 `true`。 | `5 <= 6 // true` |
|
|
|
|
|
| `>` | **大於**: 比較兩數,當左數大於右數時,回傳 `true`。 | `5 > 6 // false` |
|
|
|
|
|
| `>=` | **大於等於**: 比較兩數,當左數大於右數或左數等於右數時,回傳 `true`。 | `5 >= 6 // false` |
|
|
|
|
|
| `===` | **嚴格相等**: 比較兩數,當左數等於右數且有相同的資料型態時,回傳 `true`。 | `5 === 6 // false` |
|
|
|
|
|
| `!==` | **嚴格不等於**: 比較兩數,回傳值與嚴格相等恰恰相反。 | `5 !== 6 // true` |
|
|
|
|
|
|
|
|
|
|
✅ 藉由在瀏覽器命令欄中撰寫關係運算子來驗證你學到的知識。你有什麼意外發現嗎?
|
|
|
|
|
|
|
|
|
|
## If 條件式
|
|
|
|
|
|
|
|
|
|
當條件成立時,If 條件式會執行區塊內的程式碼。
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
if (condition){
|
|
|
|
|
//Condition was true. Code in this block will run.
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
邏輯運算子常被用在建立條件上。
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
let currentMoney;
|
|
|
|
|
let laptopPrice;
|
|
|
|
|
|
|
|
|
|
if (currentMoney >= laptopPrice){
|
|
|
|
|
//Condition was true. Code in this block will run.
|
|
|
|
|
console.log("Getting a new laptop!");
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## IF..Else 條件式
|
|
|
|
|
|
|
|
|
|
當條件不成立時,`else` 條件式會執行區塊內的程式碼。它可以和 `if` 條件式選擇性地使用。
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
let currentMoney;
|
|
|
|
|
let laptopPrice;
|
|
|
|
|
|
|
|
|
|
if (currentMoney >= laptopPrice){
|
|
|
|
|
// if 條件成立時,這段程式碼會被執行。
|
|
|
|
|
console.log("Getting a new laptop!");
|
|
|
|
|
}
|
|
|
|
|
else{
|
|
|
|
|
// else 條件成立時,這段程式碼會被執行。
|
|
|
|
|
console.log("Can't afford a new laptop, yet!");
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
✅ 在瀏覽器命令欄中測試你是否了解上述程式碼的意義。改變變數 currentMoney 和 laptopPrice 的數值來取得不同的回傳值 `console.log()`。
|
|
|
|
|
|
|
|
|
|
## 邏輯運算子與布林
|
|
|
|
|
|
|
|
|
|
有時候條件內容包含兩個以上的比較,邏輯運算子可以協助串接比較式來回傳布林值。
|
|
|
|
|
|
|
|
|
|
| 符號 | 描述 | 舉例 |
|
|
|
|
|
| ------ | -------------------------------------------------------------------------- | --------------------------------------------------------- |
|
|
|
|
|
| `&&` | **邏輯和**: 比較兩個布林條件式,當兩者**皆**回傳 `true` 時,回傳 `true`。 | `(5 > 6) && (5 < 6 ) //左為false、右為true,回傳 false。` |
|
|
|
|
|
| `\|\|` | **邏輯或**: 比較兩個布林條件式,當其中一個回傳 `true` 時,回傳 `true`。 | `(5 > 6) \|\| (5 < 6) //左為false、右為true,回傳 true。` |
|
|
|
|
|
| `!` | **邏輯非**: 回傳布林條件式的相反回傳值。 | `!(5 > 6) // 5 不大於 6,但 "!" 讓回傳值為 true。` |
|
|
|
|
|
|
|
|
|
|
## 邏輯運算子下的決定與條件
|
|
|
|
|
|
|
|
|
|
邏輯運算子可以用在建立 if..else 條件式中的條件。
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
let currentMoney;
|
|
|
|
|
let laptopPrice;
|
|
|
|
|
let laptopDiscountPrice = laptopPrice - (laptopPrice * .20) //Laptop price at 20 percent off
|
|
|
|
|
|
|
|
|
|
if (currentMoney >= laptopPrice || currentMoney >= laptopDiscountPrice){
|
|
|
|
|
// if 條件成立時,這段程式碼會被執行。
|
|
|
|
|
console.log("Getting a new laptop!");
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
// else 條件成立時,這段程式碼會被執行。
|
|
|
|
|
console.log("Can't afford a new laptop, yet!");
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### 否定運算子
|
|
|
|
|
|
|
|
|
|
你已經了解如何在 `if...else` 條件式中建立條件。任何 `if` 條件需要決定它的是與否。利用運算子 `!` 來 _否定_ 結果。它以下列方式呈現:
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
if (!condition) {
|
|
|
|
|
// condition 為 false 時,執行。
|
|
|
|
|
} else {
|
|
|
|
|
// condition 為 true 時,執行。
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### 條件運算子
|
|
|
|
|
|
|
|
|
|
`if...else` 並不是唯一表達條件式的方式。你也可以使用名為條件運算子的符號。語法如下:
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
let variable = condition ? <條件成立時回傳 A> : <條件否定時回傳 B>
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
下列是較明確的例子:
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
let firstNumber = 20;
|
|
|
|
|
let secondNumber = 10
|
|
|
|
|
let biggestNumber = firstNumber > secondNumber ? firstNumber: secondNumber;
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
✅ 花點時間閱讀這段程式碼。你能了解這些運算子的運作方式嗎?
|
|
|
|
|
|
|
|
|
|
上述的狀態為:
|
|
|
|
|
- 若 `firstNumber` 大於 `secondNumber` 時
|
|
|
|
|
- 則賦予 `firstNumber` 數值 `biggestNumber`
|
|
|
|
|
- 否則賦予為數值 `secondNumber`。
|
|
|
|
|
|
|
|
|
|
條件運算子的另一種表達方式為:
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
let biggestNumber;
|
|
|
|
|
if (firstNumber > secondNumber) {
|
|
|
|
|
biggestNumber = firstNumber;
|
|
|
|
|
} else {
|
|
|
|
|
biggestNumber = secondNumber;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
## 🚀 挑戰
|
|
|
|
|
|
|
|
|
|
建立一個程式,使用邏輯運算式來做判斷,再將程式碼改寫成條件運算子。你喜歡用哪一種語法?
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
|
## 課後測驗
|
|
|
|
|
[課後測驗](https://happy-mud-02d95f10f.azurestaticapps.net/quiz/12?loc=zh_tw)
|
|
|
|
|
|
|
|
|
|
## 複習與自學
|
|
|
|
|
|
|
|
|
|
閱讀更多可被使用的運算子:[MDN](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators)。
|
|
|
|
|
|
|
|
|
|
瀏覽 Josh Comeau 所編制的[運算子查詢表](https://joshwcomeau.com/operator-lookup/)!
|
|
|
|
|
|
|
|
|
|
## 作業
|
|
|
|
|
|
|
|
|
|
[運算子](assignment.zh-tw.md)
|