TypeScript 菜鳥教程

TypeScript 是 JavaScript 的超集,為 JavaScript 添加了類型註解和其他高級特性,使得編碼更加可靠、易於維護和高效。TypeScript 可以編譯成純 JavaScript,被廣泛應用於開發大型的 Web 應用程序和框架。本教程將從入門基礎到高級特性,逐步展示 TypeScript 的強大。

一、TypeScript 入門

1、安裝 TypeScript

對於新手,建議使用 npm(Node.js 自帶的包管理器)進行安裝。打開終端,輸入以下命令即可安裝 TypeScript。

npm install -g typescript

2、第一個 TypeScript 程序

首先,我們需要創建一個 TypeScript 文件,即以 .ts 後綴結尾的文本文件。在我們的編輯器中,創建一個 main.ts 文件,寫入以下代碼:

function greeter(person: string) {
    return "Hello, " + person;
}

let user = "TypeScript";

document.body.innerHTML = greeter(user);

3、編譯 TypeScript

通過以下命令編譯 TypeScript 文件:

tsc main.ts

該命令將 main.ts 編譯為 main.js 文件,我們可以在瀏覽器中打開該文件來運行我們的程序。

二、TypeScript 基礎

1、類型註解

TypeScript 的一個關鍵特性是類型註解,在變數聲明或函數參數前面加上類型註解,可以指定變數或參數的類型。例如:

let num: number = 42;

function add(a: number, b: number): number {
    return a + b;
}

2、介面

TypeScript 中的介面用來描述對象的形狀,即對象具有哪些屬性和方法。例如:

interface Person {
    firstName: string;
    lastName: string;
    age?: number;
}

function greeter(person: Person) {
    return "Hello, " + person.firstName + " " + person.lastName;
}

let user = { firstName: "TypeScript", lastName: "Learner", age: 25 };

document.body.innerHTML = greeter(user);

注意,age 屬性是可選的,即可以有也可以沒有。

三、TypeScript 進階

1、類和繼承

TypeScript 支持面向對象編程,可以通過 class 關鍵字定義類和繼承關係。例如:

class Animal {
    name: string;
    constructor(name: string) {
        this.name = name;
    }
    move(distanceInMeters: number = 0) {
        console.log(`${this.name} moved ${distanceInMeters}m.`);
    }
}

class Snake extends Animal {
    constructor(name: string) {
        super(name);
    }
    move(distanceInMeters = 5) {
        console.log("Slithering...");
        super.move(distanceInMeters);
    }
}

let sam = new Snake("Sammy");

sam.move();

2、泛型

TypeScript 支持泛型,即可以在定義函數、類、介面時使用未知類型。例如:

function identity(arg: T): T {
    return arg;
}

let output = identity("TypeScript");

console.log(output);

3、枚舉

TypeScript 中的枚舉用於定義命名常量,可以方便地表示一組關聯的值。例如:

enum Color {
    Red,
    Green,
    Blue,
}

let c: Color = Color.Green;

console.log(c);

四、TypeScript 實戰

1、React with TypeScript

TypeScript 可以為 React 提供類型檢查,使得 React 開發更加穩定可靠。以下是一個簡單的 TypeScript React 組件的示例:

interface Props {
    name: string;
}

const Hello: React.FC = ({ name }) => {
    return 

Hello, {name}!

; }; ReactDOM.render(, document.getElementById("root"));

2、Express with TypeScript

TypeScript 可以為 Express 提供類型檢查和智能提示,使得 Node.js 後端開發更加高效。以下是一個簡單的 TypeScript Express 應用程序的示例:

import express, { Request, Response } from "express";

const app = express();

app.get("/", (req: Request, res: Response) => {
    res.send("Hello, TypeScript!");
});

app.listen(3000, () => {
    console.log("Server started on port 3000");
});

3、TypeScript with Firebase Cloud Functions

Firebase Cloud Functions 可以使用 TypeScript 進行開發,通過 TypeScript 提供的類型安全和智能提示,可以更加輕鬆地構建出高效可靠的雲函數。以下是一個簡單的 TypeScript Firebase Cloud Function 的示例:

import * as functions from "firebase-functions";

export const helloWorld = functions.https.onRequest((request, response) => {
    response.send("Hello, TypeScript!");
});

總結

本教程只是介紹了 TypeScript 的入門、基礎、進階和實戰等方面,實際上 TypeScript 還有很多其他強大的特性和用法。希望本教程能夠幫助大家快速入門 TypeScript,從而提高開發效率和代碼質量。

原創文章,作者:IDPVE,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/332407.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
IDPVE的頭像IDPVE
上一篇 2025-01-21 17:30
下一篇 2025-01-24 18:46

相關推薦

  • MQTT使用教程

    MQTT是一種輕量級的消息傳輸協議,適用於物聯網領域中的設備與雲端、設備與設備之間的數據傳輸。本文將介紹使用MQTT實現設備與雲端數據傳輸的方法和注意事項。 一、準備工作 在使用M…

    編程 2025-04-29
  • Python3.6.5下載安裝教程

    Python是一種面向對象、解釋型計算機程序語言。它是一門動態語言,因為它不會對程序員提前聲明變數類型,而是在變數第一次賦值時自動識別該變數的類型。 Python3.6.5是Pyt…

    編程 2025-04-29
  • Deepin系統分區設置教程

    本教程將會詳細介紹Deepin系統如何進行分區設置,分享多種方式讓您了解如何規劃您的硬碟。 一、分區的基本知識 在進行Deepin系統分區設置之前,我們需要了解一些基本分區概念。 …

    編程 2025-04-29
  • 寫代碼新手教程

    本文將從語言選擇、學習方法、編碼規範以及常見問題解答等多個方面,為編程新手提供實用、簡明的教程。 一、語言選擇 作為編程新手,選擇一門編程語言是很關鍵的一步。以下是幾個有代表性的編…

    編程 2025-04-29
  • Qt雷達探測教程

    本文主要介紹如何使用Qt開發雷達探測程序,並展示一個簡單的雷達探測示例。 一、環境準備 在開始本教程之前,需要確保你的開發環境已經安裝Qt和Qt Creator。如果沒有安裝,可以…

    編程 2025-04-29
  • 猿編程python免費全套教程400集

    想要學習Python編程嗎?猿編程python免費全套教程400集是一個不錯的選擇!下面我們來詳細了解一下這個教程。 一、課程內容 猿編程python免費全套教程400集包含了從P…

    編程 2025-04-29
  • Python煙花教程

    Python煙花代碼在近年來越來越受到人們的歡迎,因為它可以讓我們在終端里玩煙花,不僅具有視覺美感,還可以通過代碼實現動畫和音效。本教程將詳細介紹Python煙花代碼的實現原理和模…

    編程 2025-04-29
  • 使用Snare服務收集日誌:完整教程

    本教程將介紹如何使用Snare服務收集Windows伺服器上的日誌,並將其發送到遠程伺服器進行集中管理。 一、安裝和配置Snare 1、下載Snare安裝程序並安裝。 https:…

    編程 2025-04-29
  • Python畫K線教程

    本教程將從以下幾個方面詳細介紹Python畫K線的方法及技巧,包括數據處理、圖表繪製、基本設置等等。 一、數據處理 1、獲取數據 在Python中可以使用Pandas庫獲取K線數據…

    編程 2025-04-28
  • Python語言程序設計教程PDF趙璐百度網盤介紹

    Python語言程序設計教程PDF趙璐百度網盤是一本介紹Python語言編程的入門教材,本文將從以下幾個方面對其進行詳細闡述。 一、Python語言的特點 Python語言屬於解釋…

    編程 2025-04-28

發表回復

登錄後才能評論