亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Typescript中Type check類型檢查的實(shí)現(xiàn)

 更新時(shí)間:2025年10月10日 09:26:58   作者:心隨雨下  
本文主要介紹了Typescript中Type check類型檢查的實(shí)現(xiàn),類型檢查是一項(xiàng)非常重要的特性,它可以幫助你捕獲潛在的錯(cuò)誤,下面就來詳細(xì)的介紹一下如何實(shí)現(xiàn),感興趣的可以了解一下

TypeScript 的類型檢查是其核心特性之一,它提供了強(qiáng)大的靜態(tài)類型系統(tǒng)。

1. 基礎(chǔ)類型檢查

基本類型注解

// 基本類型
let name: string = "John";
let age: number = 30;
let isActive: boolean = true;
let nothing: null = null;
let undef: undefined = undefined;

// 數(shù)組
let numbers: number[] = [1, 2, 3];
let names: Array<string> = ["Alice", "Bob"];

// 元組
let tuple: [string, number] = ["hello", 42];

2. 對(duì)象類型檢查

接口(Interface)

interface User {
  id: number;
  name: string;
  email?: string; // 可選屬性
  readonly createdAt: Date; // 只讀屬性
}

const user: User = {
  id: 1,
  name: "John",
  createdAt: new Date()
};

// 錯(cuò)誤:缺少必需的屬性
// const invalidUser: User = { id: 1 }; // Error: Property 'name' is missing

// 錯(cuò)誤:修改只讀屬性
// user.createdAt = new Date(); // Error: Cannot assign to 'createdAt'

類型別名(Type Alias)

type Point = {
  x: number;
  y: number;
};

type ID = number | string;

3. 函數(shù)類型檢查

// 函數(shù)聲明
function add(a: number, b: number): number {
  return a + b;
}

// 函數(shù)表達(dá)式
const multiply: (x: number, y: number) => number = function(x, y) {
  return x * y;
};

// 箭頭函數(shù)
const divide = (a: number, b: number): number => a / b;

// 可選參數(shù)和默認(rèn)參數(shù)
function greet(name: string, greeting: string = "Hello"): string {
  return `${greeting}, ${name}!`;
}

// 剩余參數(shù)
function sum(...numbers: number[]): number {
  return numbers.reduce((acc, curr) => acc + curr, 0);
}

4. 聯(lián)合類型和交叉類型

// 聯(lián)合類型
type Status = "pending" | "success" | "error";
let currentStatus: Status = "pending";

type StringOrNumber = string | number;
let value: StringOrNumber = "hello";
value = 42;

// 交叉類型
interface Named {
  name: string;
}

interface Aged {
  age: number;
}

type Person = Named & Aged;
const person: Person = { name: "John", age: 30 };

5. 泛型類型檢查

// 泛型函數(shù)
function identity<T>(arg: T): T {
  return arg;
}

// 泛型接口
interface Response<T> {
  data: T;
  status: number;
}

const userResponse: Response<User> = {
  data: { id: 1, name: "John", createdAt: new Date() },
  status: 200
};

// 泛型約束
interface HasLength {
  length: number;
}

function logLength<T extends HasLength>(arg: T): void {
  console.log(arg.length);
}

6. 高級(jí)類型檢查

類型守衛(wèi)(Type Guards)

function isString(value: any): value is string {
  return typeof value === "string";
}

function processValue(value: string | number) {
  if (isString(value)) {
    // TypeScript 知道這里 value 是 string 類型
    console.log(value.toUpperCase());
  } else {
    // TypeScript 知道這里 value 是 number 類型
    console.log(value.toFixed(2));
  }
}

keyof 和 typeof

interface User {
  id: number;
  name: string;
  email: string;
}

type UserKeys = keyof User; // "id" | "name" | "email"

const user = { name: "John", age: 30 };
type UserType = typeof user; // { name: string; age: number; }

7. 嚴(yán)格的類型檢查選項(xiàng)

在 tsconfig.json 中啟用嚴(yán)格模式:

{
  "compilerOptions": {
    "strict": true,
    "noImplicitAny": true,
    "noImplicitReturns": true,
    "noUnusedLocals": true,
    "noUnusedParameters": true,
    "exactOptionalPropertyTypes": true,
    "noImplicitOverride": true
  }
}

具體嚴(yán)格選項(xiàng):

  • strict: 啟用所有嚴(yán)格類型檢查選項(xiàng)
  • noImplicitAny: 禁止隱含的 any 類型
  • strictNullChecks: 嚴(yán)格的 null 檢查
  • strictFunctionTypes: 嚴(yán)格的函數(shù)類型檢查
  • strictPropertyInitialization: 嚴(yán)格的屬性初始化檢查

8. 類型推斷

TypeScript 在很多情況下可以自動(dòng)推斷類型:

// 類型推斷
let message = "hello"; // 推斷為 string 類型
let count = 42; // 推斷為 number 類型

// 函數(shù)返回類型推斷
function createUser(name: string, age: number) {
  return { name, age }; // 推斷返回類型為 { name: string; age: number }
}

// 上下文類型推斷
const buttons = document.querySelectorAll("button");
buttons.forEach(button => {
  button.addEventListener("click", e => {
    // e 被推斷為 MouseEvent
    console.log(e.target);
  });
});

9. 類型兼容性

TypeScript 使用結(jié)構(gòu)化類型系統(tǒng):

interface Point {
  x: number;
  y: number;
}

interface NamedPoint {
  x: number;
  y: number;
  name: string;
}

let point: Point = { x: 1, y: 2 };
let namedPoint: NamedPoint = { x: 1, y: 2, name: "origin" };

point = namedPoint; // OK: NamedPoint 包含 Point 的所有屬性
// namedPoint = point; // Error: Point 缺少 name 屬性

10. 實(shí)用類型(Utility Types)

interface User {
  id: number;
  name: string;
  email: string;
  age: number;
}

// Partial: 所有屬性變?yōu)榭蛇x
type PartialUser = Partial<User>;

// Readonly: 所有屬性變?yōu)橹蛔x
type ReadonlyUser = Readonly<User>;

// Pick: 選擇部分屬性
type UserBasicInfo = Pick<User, "id" | "name">;

// Omit: 排除部分屬性
type UserWithoutEmail = Omit<User, "email">;

// Record: 創(chuàng)建鍵值對(duì)類型
type UserMap = Record<string, User>;

TypeScript 的類型檢查系統(tǒng)非常強(qiáng)大,能夠在編譯時(shí)捕獲許多常見的錯(cuò)誤,提供更好的開發(fā)體驗(yàn)和代碼質(zhì)量。

到此這篇關(guān)于Typescript中Type check類型檢查的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Typescript Type check類型檢查內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JavaScript利用正則表達(dá)式替換字符串中的內(nèi)容

    JavaScript利用正則表達(dá)式替換字符串中的內(nèi)容

    本文主要介紹了JavaScript利用正則表達(dá)式替換字符串中內(nèi)容的具體實(shí)現(xiàn)方法,并做了簡(jiǎn)要注釋,便于理解。具有一定的參考價(jià)值,需要的朋友可以看下
    2016-12-12
  • javascript解析xml實(shí)現(xiàn)省市縣三級(jí)聯(lián)動(dòng)的方法

    javascript解析xml實(shí)現(xiàn)省市縣三級(jí)聯(lián)動(dòng)的方法

    這篇文章主要介紹了javascript解析xml實(shí)現(xiàn)省市縣三級(jí)聯(lián)動(dòng)的方法,涉及javascript針對(duì)節(jié)點(diǎn)的操作與XML文件解析的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • JS小游戲之極速快跑源碼詳解

    JS小游戲之極速快跑源碼詳解

    這篇文章主要介紹了JS小游戲之極速快跑源碼詳解,對(duì)游戲的主要流程及原理進(jìn)行了較為詳細(xì)的講解,并附有完整實(shí)例源碼,需要的朋友可以參考下
    2014-09-09
  • js阻止瀏覽器默認(rèn)行為的簡(jiǎn)單實(shí)例

    js阻止瀏覽器默認(rèn)行為的簡(jiǎn)單實(shí)例

    下面小編就為大家?guī)硪黄猨s阻止瀏覽器默認(rèn)行為的簡(jiǎn)單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-05-05
  • firefox和IE系列的相關(guān)區(qū)別整理 以備后用

    firefox和IE系列的相關(guān)區(qū)別整理 以備后用

    firefox和IE系列的相關(guān)區(qū)別整理,整理相對(duì)來說還可以,但對(duì)于個(gè)別細(xì)節(jié)的處理不夠完善。具體的可以參考腳本*之家以前發(fā)布的文章。
    2009-12-12
  • Javascript圖像處理—為矩陣添加常用方法

    Javascript圖像處理—為矩陣添加常用方法

    上一篇文章,我們定義了矩陣,這篇文章我們來給矩陣添加一些常用方法比如:toString方法、clone方法等,需要了解的朋友可以詳細(xì)參考下
    2012-12-12
  • 微信小程序8種數(shù)據(jù)通信的方式小結(jié)

    微信小程序8種數(shù)據(jù)通信的方式小結(jié)

    這篇文章主要介紹了微信小程序8種數(shù)據(jù)通信的方式小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • layui 中select下拉change事件失效的解決方法

    layui 中select下拉change事件失效的解決方法

    今天小編就為大家分享一篇layui 中select下拉change事件失效的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 動(dòng)態(tài)加載script文件的兩種方法

    動(dòng)態(tài)加載script文件的兩種方法

    第一種就是利用ajax方式,第二種是,動(dòng)態(tài)創(chuàng)建一個(gè)script標(biāo)簽,設(shè)置其src屬性,通過把script標(biāo)簽插入到頁面head來加載js,感興趣的朋友可以了解下
    2013-08-08
  • 原生js實(shí)現(xiàn)的觀察者和訂閱者模式簡(jiǎn)單示例

    原生js實(shí)現(xiàn)的觀察者和訂閱者模式簡(jiǎn)單示例

    這篇文章主要介紹了原生js實(shí)現(xiàn)的觀察者和訂閱者模式,結(jié)合簡(jiǎn)單實(shí)例形式分析了js觀察者和訂閱者模式的相關(guān)原理與實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2020-04-04

最新評(píng)論