Jen Looper
5d6c46ec6f
|
4 years ago | |
---|---|---|
.. | ||
README.de.md | 4 years ago | |
README.es.md | 4 years ago | |
README.id.md | 4 years ago | |
README.it.md | 4 years ago | |
README.ja.md | 4 years ago | |
README.ko.md | 4 years ago | |
README.ms.md | 4 years ago | |
README.zh-tw.md | 4 years ago | |
assignment.de.md | 4 years ago | |
assignment.es.md | 4 years ago | |
assignment.hi.md | 4 years ago | |
assignment.id.md | 4 years ago | |
assignment.it.md | 4 years ago | |
assignment.ja.md | 4 years ago | |
assignment.ko.md | 4 years ago | |
assignment.ms.md | 4 years ago | |
assignment.nl.md | 4 years ago | |
assignment.zh-tw.md | 4 years ago |
README.zh-tw.md
JavaScript 入門 - 做出決定
由 Tomomi Imura 繪製
課前測驗
為程式碼做決定與控制順序以提高其重複利用性與豐富性。這堂課程提供 JavaScript 的資料流控制語法與布林資料型的重點。
點擊上方圖片以觀賞關於程式做決定的影片。
回顧布林資料型
布林只能有兩種數值: 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 條件式會執行區塊內的程式碼。
if (condition){
//Condition was true. Code in this block will run.
}
邏輯運算子常被用在建立條件上。
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
條件式選擇性地使用。
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 條件式中的條件。
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
條件需要決定它的是與否。利用運算子 !
來 否定 結果。它以下列方式呈現:
if (!condition) {
// condition 為 false 時,執行。
} else {
// condition 為 true 時,執行。
}
條件運算子
if...else
並不是唯一表達條件式的方式。你也可以使用名為條件運算子的符號。語法如下:
let variable = condition ? <條件成立時回傳 A> : <條件否定時回傳 B>
下列是較明確的例子:
let firstNumber = 20;
let secondNumber = 10
let biggestNumber = firstNumber > secondNumber ? firstNumber: secondNumber;
✅ 花點時間閱讀這段程式碼。你能了解這些運算子的運作方式嗎?
上述的狀態為:
- 若
firstNumber
大於secondNumber
時 - 則賦予
firstNumber
數值biggestNumber
- 否則賦予為數值
secondNumber
。
條件運算子的另一種表達方式為:
let biggestNumber;
if (firstNumber > secondNumber) {
biggestNumber = firstNumber;
} else {
biggestNumber = secondNumber;
}
🚀 挑戰
建立一個程式,使用邏輯運算式來做判斷,再將程式碼改寫成條件運算子。你喜歡用哪一種語法?
課後測驗
複習與自學
閱讀更多可被使用的運算子:MDN。
瀏覽 Josh Comeau 所編制的運算子查詢表!