JavaScript極簡入門教程(一):基礎篇_javascript技巧

來源:互聯網
上載者:User

閱讀本文需要有其他語言的編程經驗。

開始學習之前

大多數的程式設計語言都存在好的部分和差的部分。本文只講述 JavaScript 中好的部分,這是因為:

1.僅僅學習好的部分能夠縮短學習時間
2.編寫的代碼更加健壯
3.編寫的代碼更加易讀
4.編寫的代碼更加易於維護

弱類型和強型別

通常來說,越早的修複錯誤,為之付出的代價就越小。強型別語言的編譯器可以在編譯時間檢查某些錯誤。而 JavaScript 是一門弱類型語言,其解譯器無法檢查類型錯誤,但實踐表明:

1.強型別能夠避免的錯誤並不是那些關鍵性錯誤
2.弱類型能夠帶來靈活性,也無需背上強型別的包袱

JavaScript 相關標準

ECMA-262 標準定義了語言 ECMAScript。我們所熟知的 JavaScript 和 ActionScript 都是基於 ECMAScript 的。目前主流使用 ECMA-262 第五版,Google 的 V8 引擎就是對此的實現。

Hello JavaScript

JavaScript 是一門指令碼語言,需要解譯器解釋執行。你可以在瀏覽器中解釋執行 JavaScript 或者直接使用 node.js,node.js 整合了 Google 的 V8 JavaScript 引擎。由於 node.js 使用非常方便,由此,這裡我使用 node.js 來解釋執行 JavaScript。現在看第一個 JavaScript 程式:

複製代碼 代碼如下:

// test.js
console.log("Hello JavaScript");

執行此程式:

複製代碼 代碼如下:

node test.js

文法

注釋

JavaScript 使用和 C++ 相同的注釋方式,// 用於單行注釋,/* */ 用於多行注釋。

數字類型

JavaScript 僅有一種數字類型,也就是 64 位元浮點數。數字類型有兩個特殊的值 NaN 和 Infinity,NaN 的含義為 not a number(不是一個數),使用函數 isNaN 檢查是否為 NaN,值 Infinity 表示無窮大。在 Math 對象中,有一組運算元字的方法,例如:Math.floor 方法用於向下取整。

字串

字串 literal 可以被包裹在單引號或者雙引號中,逸出字元使用 \(和其他很多語言沒有什麼不同)。JavaScript 中每個字元都是兩個位元組,其使用 Unicode 字元集。字串有一個 length 屬性:

複製代碼 代碼如下:

"Hello".length // 值為 5,注意不是 "Hello".length()

字串是不可以改變的(和 Lua 一樣),除了這裡說的 length 屬性,還有一些方法,例如:

複製代碼 代碼如下:

'cat'.toUpperCase() === 'CAT'

語句

var 語句用於聲明局部變數,否則變數為全域變數,未初始化的變數的值為 undefined:

複製代碼 代碼如下:

function f() {
    var localVar = 123;
    globalVar = 456;
    var i; // i 的值為 undefined
};
 
f();
 
console.log(globalVar); // ok
console.log(localVar); // 錯誤,localVar 沒有被定義

由 {} 包裹的一組語句被叫做語句塊(Block),和其他語言不同的是,JavaScript 中的函數會而塊不會建立新的範圍,例如:

複製代碼 代碼如下:

{
    var v = 123;
}
console.log(v); // ok

if 語句

複製代碼 代碼如下:

if (expression)
    statement

或者

複製代碼 代碼如下:

if (expression)
    statement1
else
    statement2

或者

複製代碼 代碼如下:

if (expression1)
    statement1
else if (expression2)
    statement2
else if (expression3)
    statement3
else
    statement4

if 語句通過判斷運算式的值為真或假來決定執行或者跳過某些語句。在 JavaScript 中以下值為假(其他值均為真):

1.false
2.null
3.undefined
4.Null 字元串
5.0
6.NaN

if 中的 statement 可以是一個語句,也可以是一個語句塊。

switch 語句

複製代碼 代碼如下:

switch (n) {
    case 1: // 如果 n 等於 1
    // 執行代碼塊
    break;
    case 2: // 如果 n 等於 2
    // 執行代碼塊
    break;
    default: // 如果 n 不為 1 也不為 2
    // 執行代碼塊
    break;
}

這裡的 break 用於退出迴圈語句或者 switch 語句。在 JavaScript 中,比較兩個值是否相等有兩個操作符:

1.==(對應 != 操作符),相等,兩個運算元類型不同時,此運算子嘗試運算元類型轉換後再進行比較,例如:

複製代碼 代碼如下:

var x = 1;
x == 1; // true
x == "1"; // true

2.===(對應 !== 操作符),完全相等,比較兩個運算元,不進行運算元類型轉換,例如:

複製代碼 代碼如下:

var x = 1;
x === 1; // true
x === "1"; // false

需要注意的是 NaN 和任何值都不相等,如果 x 為 NaN,那麼 x !== x(僅對 NaN 成立),我們可以這樣實現 isNaN 函數:

複製代碼 代碼如下:

function isNaN(n) {
    return n !== n;
}

上面 switch 語句,轉換為 if 語句為:

複製代碼 代碼如下:

if (n === 1)
    // ...
else if (n === 2)
    // ...
else
    // ...

while 和 do-while 語句

複製代碼 代碼如下:

while (expression)
    statement

如果 expression 為真則重複執行 statement 直到 expression 為假。

複製代碼 代碼如下:

do
    statement
while (expression);

類似 while 迴圈,只是先執行 statement,然後再檢查條件 expression。

for 語句

複製代碼 代碼如下:

for (initialize ; test ; increment)
    statement

首先 initialize 被執行一次(常用來初始化迴圈變數),然後進行 test 條件測試(常用來測試迴圈變數),如果 test 條件為假則停止迴圈,否則執行 statement,然後執行 increment(常用來更新迴圈變數),接著又進行 test 條件測試,如此迴圈執行下去。使用範例:

複製代碼 代碼如下:

for (var i=0; i<5; ++i) {
    console.log(i);
}

for 的另外一種形式被用於枚舉一個對象的所有屬性名稱:

複製代碼 代碼如下:

for (variable in object)
    statement

範例:

複製代碼 代碼如下:

var obj = {
    a: 1,
    b: 2,
    c: 3
};
 
for (var name in obj)
    console.log(name);

需要注意的是,我們通過 hasOwnProperty 方法來檢查屬性名稱是該對象的,還是從原型鏈(prototype chain,prototype 會在 下一篇 中介紹)中找到的:

複製代碼 代碼如下:

for (var in obj) {
    if (obj.hasOwnProperty(var)) {
        // ...
    }
}

return 語句

return 語句用於讓函數返回一個值,如果函數沒有顯式的使用 return,那麼返回 undefined:

複製代碼 代碼如下:

function f() { }
var v = f(); // v === undefined

?: 條件操作符(JavaScript 中唯一的一個三元操作符)
?: 條件操作符在很多程式設計語言中都存在,在第一個運算元為真時,操作符返回第二個運算元的值,否則返回第三個運算元的值,使用範例:

複製代碼 代碼如下:

function abs() {
    return x > 0 ? x : -x;
}

typeof 操作符

typeof 操作符用於擷取變數的類型,其傳回值包括:

1.'number'
2.'string'
3.'boolean'
4.'undefined'
5.'function'
6.'object'

特別的 typeof null 返回的結果是 'object'。關於 typeof 的範例:

複製代碼 代碼如下:

var a = typeof 'hello'; // a === 'string'
var b = typeof null; // b === 'object'

+ 操作符

+ 操作符在 JavaScript 中可以用於加法運算,也可以用於字串串連:

複製代碼 代碼如下:

var message = 'hello' + 'world'; // message === 'helloworld'

&& 和 || 運算子

&& 操作符在第一個運算元為假時返回第一個運算元的值,否則返回第二個運算元的值
|| 操作符在第一個運算元為真時返回第一個運算元的值,否則返回第二個運算元的值

複製代碼 代碼如下:

var a = 1 && true; // a === true
var b = 1 || false; // b === 1

|| 的一個習慣用法:

複製代碼 代碼如下:

name = name || 'unknown'; // 為 name 設定預設值 'unknown'

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.