Lecture 04 - JavaScript 簡介
Last updated
Last updated
對於初學者來說相對容易學習
只需學習一次,可在任何地方使用 (Web / 桌面 / Linux)
有龐大的社群支援以及擁有豐富的庫支援 npm
🖥 網頁瀏覽器 (使用 V8 引擎)
📱 Android (使用 V8 引擎和瀏覽器)
📲 IOS (使用 V8 引擎和瀏覽器)
🖥 Windows (使用 Nodejs)
💻 MacOS (使用 Nodejs)
🖱 Linux (使用 Nodejs)
幾乎你日常生活中所看到的任何東西都可以運行 JavaScript。
app.js
然後在終端機中輸入 node app.js 以執行腳本。
注意:如果您沒有安裝 nodejs,請立即從 https://nodejs.org/en/ 安裝它。
console.log();
這是 JavaScript 中用來列印訊息的基本函數
資料類型 Data Types
算術運算子 Arithmetic Operators
賦值運算子 Assignment Operators
定義變數 Define variables
條件語句 Conditional Statements
比較語句 Compare Statements
函式 Functions
用於解釋代碼,並使其更可讀 註解中的代碼將不會運行/執行/編譯
單行註解以 //
開頭。
多行註解以 /*
開頭,以 */
結尾.
string
字串型別,例如 "Hello"
, "Good day"
, "I go to school by bus"
number
數值型別,例如 12
, -3
, 32.476
, 0x012
, 11010010
boolean
布林型別,例如 true
, false
string
顯示常見的字串 / 字元
"Hello world"
, "a"
, "😀"
(Using " ) (使用雙引號)
'Hello mate'
, 'b'
, '😍'
(Using ' ) (使用單引號)
`Hello mom`
, `c`
, `😎`
(Using ` ) (使用反引號)
number
代表數學運算中的數值資料型別 ( +
, -
, *
, /
, %
)
Integer 整數: 1
, 384
Signed Integer 有正負號的整數: 1
, 384
, -43
Float / Double 浮點數 / 雙精度浮點數: 1.23
, -34.3423
, 0.001
(Float 浮點數 = 單精度,Double 雙精度浮點數 = 雙精度)
Infinity 無限大: infinity
, -infinity
number
基本算術運算子+
: Addition 加法 (e.g. 3 + 5 = 8
)
-
: Subtraction 減法 (e.g. 8 - 2 = 6
)
*
: Multiplication 乘法 (e.g. 3 * 4 = 12
)
/
: Division 除法 (e.g. 10 / 5 = 2
, 14 / 5 = 2.8
)
通常在一般情況下使用的
**
: 指數運算 Exponentiation ( 2^3
=> 2**3
)
%
: 取模運算 / 求餘數 Modulus / Remainder ( 5 % 2 == 1
, 10 % 2 == 0
)
通常在循環中使用的
(將在下一課中介紹更多)
++
: 自增 (i++
)
--
: 自減 (i--
)
boolean
布爾值它是一種用於確定條件是否發生的數據類型。在此數據類型中,僅出現 true
和 false
。
true
: 表示條件將發生 / 匹配。
false
: 表示條件將不會發生 / 不匹配。
boolean
and &&
, or ||
, not !
在所有的程式語言中,幾個符號代表邏輯運算。
and
: 使用 &&
or
: 使用 ||
not
: 使用 !
1 = true, 0 = false
and
: 表示兩個條件都成立時,會回傳 true。
or
: 表示其中一個條件成立時,會回傳 true。
not
: 反轉條件 (!true => false
, !false => true
)
and &&
, or ||
, not !
其實這是一個現實生活中的簡單問題或邏輯句子。
如果我們要用表示一個條件:
在程式語言中,我們會這樣寫:
and
, or
, not
更複雜的條件可能會像這樣:
如果你是湯姆,想要跟彼得玩一個遊戲,你會在程式語言中如何寫呢?
samples.js
(本課程中不會涵蓋,但在未來很重要)
常用的
物件(Object)
and 陣列(Array)
Null
and 未定義(Undefined)
進階的
錯誤(Error)
日期(Date)
映射(Map)
and 集合(Set)
類別(Class)
=
x = y
x = y
+=
x += y
x = x + y
-=
x -= y
x = x - y
*=
x *= y
x = x * y
/=
x /= y
x = x / y
%=
x %= y
x = x % y
**=
x **= y
x = x ** y
一般來說,我們可以使用var
、let
或const
來定義變量。
在大多數情況下(99.99%),由於歷史原因,我們不建議使用var
. 了解更多
let
是一個定義詞,用於告訴計算機定義一個可更改的變量。
const
也是一樣的,但我們假設使用const
定義的變量是在定義之後不能被更改的變量。
let
使用let
定義的變量可以被重新定義
具有區塊作用域 (block-scope)
const
通常情況下,使用const
定義的變量不能被重新定義。
具有區塊作用域 (block-scope)
在像array
和object
這樣的數據類型中使用const
有例外情況,但我們首先假設所有const
變量都不能被重新分配。
Compare 比較運算子: ==
, ===
, !=
, !==
For Maths 數學運算子: >
, <
, >=
, <=
Logics 邏輯運算子: if
, else if
, else
==
, ===
, !=
, !==
==
: 弱等於
===
: 強等於
!=
: 弱不等於
!==
: 強不等於
Strong compare 強等
和 Weak compare 弱等
?Strong
意味著不僅值相同,而且數據類型也需要匹配。
Weak
意味著如果值相同(無論是字符串還是數字),且內容相同,則返回 true。
強等與弱等的例子
注意事項:在這個例子中,num
是一個 number
的資料型態,但是 stringNum
是一個 string
的資料型態,儘管兩者都代表了 100
。
如果不確定要使用哪種比較類型,總是使用強比較 ===
!==
來確保安全。
>
, <
, >=
, <=
>
: 大於
>=
: 大於或等於s
<
: 小於
<=
: 小於或等於
if
, else if
, else
內部程式碼將在條件滿足時運行
if(){}
如果條件成立,運行這個區塊的程式碼。
else if(){}
如果前面的條件不成立,則檢查這個條件,如果成立,運行這個區塊的程式碼。
else{}
如果前面的所有條件都不成立,則運行這個區塊的程式碼。
if
demo.js
ifDemo.js
ifDemoTwo.js
if
與 else
demo.js
ifElseDemo.js
ifElseTwoDemo.js
if
與 else
使用以下代碼邏輯上是不一樣
if
與 else
與 else if
ifElseDemo.js
ifElseDemo.js
ifElseDemo.js
函數是一個為了完成特定任務而設計的代碼塊。
basic-function.js
函數可以傳入參數,以便重複使用。
basic-function-params.js
函數也可以傳入很多參數。
basic-function-params.js
函數可以回傳 return
一個值,讓其他變數使用。
function-return.js
在 JavaScript 中,函數也可以像這樣編寫:
Peter 想要定義一些變數,但他不知道該怎麼做。你可以幫他嗎?
定義兩個 let
變數 income
和 outcome
,其值分別為 10000
和 4000
。
定義兩個 const
變數 names
和 date
,其值分別為 "Peter" 和 "2022-03-06"。
定義一個 let
變數 total
,它是基於 income - outcome
得出的總數。
lab02-template.js
編寫一個程序,根據以下要求檢查學生的教育階段:
如果學生的年齡小於5歲,他/她將處於未接受教育
狀態。 如果學生的年齡在6到12歲之間,他/她將處於小學
狀態。 如果學生的年齡在13到18歲之間,他/她將處於中學
狀態。 如果學生的年齡在19到22歲之間,他/她將處於大學
狀態。 如果學生的年齡大於23歲,他/她將處於工作
狀態。
lab02-template.js
我們學習了以下內容:
執行 app.js
用 console.log
輸出變量
資料型別 string
, number
, boolean
算術運算符 ++
, *
, /
等等
賦值運算符 =
, +=
, *=
, /=
等等
定義變量 let
, const
, var
條件語句 if
, else
比較語句 ==
, ===
, <=
等等
函數 function add(a,b){ return a + b }
在本課程中,我們沒有涉及以下內容:
Object, Array, for loop (物件、陣列、for 迴圈)
Array Looping (for, while) (陣列迴圈 (for, while))
Scope (作用域)
但如果有興趣,您可以自行閱讀 lecture-ex1
的內容。