TypeScript(基礎篇)day01

来源:https://www.cnblogs.com/heymar/archive/2022/11/10/16878869.html
-Advertisement-
Play Games

一.TS介紹 1.1 簡介 ts是2012年由微軟開發,在js的基礎上添加了類型支持 1.2 優劣勢 優勢 :任何位置都有代碼提示,增加效率;類型系統重構更容易;使用最新的ECMAscript語法 劣勢:和有些庫的結合併不是很完美;學習需要成本需要理解介面、泛型、類型等知識 1.3 與js區別 首先 ...


一.TS介紹

1.1 簡介

ts是2012年由微軟開發,在js的基礎上添加了類型支持

1.2 優劣勢

優勢 :任何位置都有代碼提示,增加效率;類型系統重構更容易;使用最新的ECMAscript語法

劣勢:和有些庫的結合併不是很完美;學習需要成本需要理解介面、泛型、類型等知識

1.3 與js區別

首先要明確,ts的存在只是為了讓編程更便捷,並不是用來取代js的,是因為js是一個弱類型沒有介面泛型而已。

image-20220923174607355

二.環境安裝

首先安裝ts,直接安裝包即可

註意是全局安裝

image-20220923181221800

然後安裝完後記得初始化ts

image-20220923181238448

初試化完之後有一個ts的配置文件,先修改兩個東西

rootdir表示我們的輸入也就是寫的代碼所在的位置

image-20220923181427950

outdir表示代碼會在此文件輸出

image-20220923181459950

2.1 js的缺陷

有這樣一段js的代碼

image-20220923182346389

當我們運行會發現執行完了第一句就報錯了

image-20220923182409730

原因就不用多說了,這就是js的一個缺陷

這個時候上ts

直接將原代碼放到ts裡面來會發現報錯

這裡提示什麼錯誤用到插件error lens

image-20220923182623510

第一個報錯是我們要把參數規定數據類型

image-20220923182734879

然後發現我們的參數有不符合類型的

image-20220923182751592

所有錯誤清除

image-20220923182802737

註意關鍵步驟來了:

剛纔我們定義了一個代碼所在目錄,需要把ts文件放進去

image-20220923183658293

然後 tsc -watch開啟ts檢測,一旦發現這個ts文件變化就會有輸出文件

image-20220923183745937

可以看到我們的ts文件已經到輸出文件的dist目錄下,並且已經轉換成js文件了

image-20220923183834152

這個時候我們直接運行轉換出來的文件

image-20220923183859111

三.數據類型

3.1 基礎數據類型

首先加一段話

意思表示,如果當我們在src下創建了一些ts文件有命名衝突的時候不加的話就會報錯,加上就相當於添加了一個模塊作用域不會報命名衝突的錯誤

image-20220927165209771

這是ts三種基礎數據類型,數值、布爾、字元串

image-20220927165354995

一定要聲明類型才能夠賦值,而且聲明瞭什麼類型就給什麼值

image-20220927165532662

3.2 數組

數組有幾種定義的方式

首先單獨定義

image-20220927171127353

單獨定義還有一種方式

image-20220927171203598

第二種是混合定義就是可以定義多個類型

跟第一種有點類似,然後用括弧括起來中間用|隔開

image-20220927171313824

最後一種是任意類型

但是並不推薦這種,因為也就失去了ts矯錯的意義

image-20220927171456136

3.3 元祖

用於保存定長長度的數組和數據類型

tuple

首先它的定義

image-20220927172009544

image-20220927172042151

這個時候就定長了,長度固定少一個不行,多一個不行

image-20220927172106135

而且對應位置的數據類型也固定了,不能顛倒

image-20220927172145201

3.4 any與void

首先any表示任意類型,當我們不清楚值的數據類型時可以用any

場景一:

當變數的值會動態改變,比如用戶的輸入時

可以看到我們這裡不論是什麼類型都不會報錯

image-20220927174048051

場景二:

改寫現有代碼時,想要去包含或者是移除類型檢查

可以看到我們並沒有定義這個函數,但是也不會報錯,這個時候用any來移除類型檢查,但是要註意這種方式不太安全

image-20220927174232129

場景三:

定義或存儲各種類型數據的數組

像這樣一個數組會有限制

image-20220927174452448

這樣就不會了

image-20220927174537706

void

某種意義上來說,void與any是相反的,因為他表示沒有任何類型

常常用於當一個函數沒有返回值時

比如這樣一個正常函數是沒有問題的

image-20220927175122641

當我加上了void來聲明後

就會報錯return這一行

image-20220927175155164

刪除後我們才可以正常執行

image-20220927175256140

還有一個點就是當給一個變數聲明為void類型,那麼他的值就只能為undefined和null

image-20220927175347953

image-20220927175403122

為null報錯是以為我們開啟了嚴格模式,需要在ts配置文件中將這一行註釋

image-20220927175438311

image-20220927175454768

3.5 null和undefined

他們的作用就不用多說了

首先他們也是一種數據類型要賦值給變數也要進行定義

image-20220927175834760

但是要註意:在非嚴格模式下,他可以賦值給其他數據類型

image-20220927175940656

3.6 never和object

never類型就是一些總是會拋出異常或者根本就不會有返回值的函數,像這些就可以定義為never類型

image-20221023113138716

object就是定義為一個對象

image-20221023113309963

3.7 枚舉

枚舉是js標準數據類型的一個補充,可以為一組 數值賦予友好的名字

通過enum來定義

image-20221023115024518

這個時候我將一個變數定義為這個類型,

image-20221023115113041

他就只能為這個類型裡面的別名或者說是數值

image-20221023115151660

然後第一個註意點,我給他賦值數值並不會出錯,因為枚舉本身就是為數值取一個好聽的別名,它的本質就是數值

image-20221023115247414

而且他預設就是從0開始的

image-20221023115353871

image-20221023115359777

第二個註意點,雖然預設從0開始,但是我們可以手動修改他的起始值,註意雖然這裡{}包裹,但是裡面是寫為等號賦值

image-20221023115515815

這個時候再去列印

image-20221023115534800

如果修改的是第二個值

image-20221023115550758

image-20221023115557205

如果修改的各自的值

image-20221023115610423

image-20221023115616267

3.8 bigInt和symbol

bigint是用來彌補我們number數據類型最大隻能到2^53-1的整數的缺陷

他的定義方法可以直接在後面加n或者調用bigint這個方法

註意這是es2020新增的類型,所以要將我們的ts轉到2020來

image-20221023121411939

json文件裡面改

image-20221023121425406

symbol的值是唯一的,獨一無二的

image-20221023121707823

並不相等,即使裡面的值都一樣但是他們都為各自的值

image-20221023121734598

3.9 變數聲明與解構

ts的變數聲明解構跟js是一樣的

首先聲明也是:var、let、const

數組解構:

第一種解構

image-20221023154740247

第二種解構,將剩餘的以一個數組存儲

image-20221023155023305

image-20221023155034112

第三種解構,可以取到我們想要的一個位置的數據

image-20221023155308110

對象解構:

image-20221023155353926

3.10 類型斷言

就是手動指定一個值的類型,不再讓js判斷,我說他是什麼就是什麼

兩種方式

第一種方式

<>裡面定義類型外面接變數名

image-20221023162009472

我如果斷言為number,它不具有length,所以就會報錯

image-20221023162612833

第二種方式

通過一個as相當於取別名的方式來定義

image-20221023162218271

應用:

比如現在有個函數,他的參數類型為number或者string,但是number沒有length所以會報錯

image-20221023162811674

我如果給她強制定義為string就不會出現錯誤

image-20221023162916482

3.11 類型別名

就是給一個類型起一個新名字,裡面可有多個數據,都是同一個類型

第一種:

type開頭聲明,中間用|隔開

定義好後變數用別名來修飾,而且變數只能取定義好的數據,包括數據類型也要相同

image-20221023170446156

第二種:函數

用類型別名聲明瞭一個函數

image-20221023170739235

我要用肯定也要用一個變數,然後用類型別名綁定給他,再去定義我們這個函數

image-20221023170843011

它的作用就是定義好了後,這個函數就只能返回number類型,其他類型都不行

image-20221023170918811

第三種:對象

定義好之後綁定給變數,我們的當前這個屬性就只能用規定好的數據類型了

image-20221023171049959

四.介面

4.1 介面基本使用

介面是一系列抽象方法的聲明,是一些方法特征的集合

interface來定義,跟type很像,但是有區別的,後面會說

定義一個介面

image-20221023171836976

然後我這邊要用同樣是綁定給他,聲明自己的數據

image-20221023171933178

函數的使用

參數採用解構賦值直接拿,然後通過定義好的介面去約束他們,再把函數定義為void類型,也就是沒有返回值

image-20221023172237240

4.2 可選屬性與只讀屬性

在我們定義介面時,某些屬性可以省略我們約束的時候可以不賦值叫做可選屬性,用?修飾

沒有修飾可選屬性,不寫的話會報錯

image-20221023175015614

寫為可選

image-20221023175032251

只讀屬性就是只能讀取,不能修改,readonly來修飾

沒有隻讀屬性時是可以修改的

image-20221023175217345

給到只讀屬性後

image-20221023175237463

我們的const和readonly的區別

因為他們兩個都是不可以修改只能夠讀取

雖然作用大致一樣,但是用處不一樣,一般一般要作為變數使用就是用const來修飾,如果要作為屬性使用就用readonly

4.3 索引簽名

用於描述那些通過索引得到的類型,解決參數問題

當我們定義好介面,如果少一個參數我們可以用可選屬性來將其可要可不要

但是如果多一個參數呢?

三種方法
第一種:不推薦

可以看到我如果直接加在後面會報錯

image-20221024095648948

但是我給一個對象之後再加在後面就不會報錯了

image-20221024095722851

這是因為ts的檢測是淺檢測,我們直接加在後面是一層,但是中間有個對象對象裡面再來一個對象,就屬於深層次了,就檢測不到了,所以這種理論上是不允許的,只是我們投機取巧,不推薦

第二種:

通過類型斷言

我們說過類型斷言,就是我自己來聲明,加上了之後就相當於脫離了ts的校驗規則,你想定義什麼就定義什麼沒有人管得到你了,註意這裡是給這個變數類型斷言,所以只能斷言為people或者any

image-20221024100543026

第三種:

索引簽名

給我們介面添加一個中括弧裡面props是變數名隨便取,第一個string為我們屬性名的類型定義,要註意對象屬性名會自動給你變成字元串,就算你沒添加引號也是字元串,後面則是規定我們值為什麼類型

image-20221024100843539

這樣我們也可以隨便添加任意類型的參數了

4.4 函數介面

函數的介面需要定義一個調用的參數的簽名以及返回值的類型

image-20221024104037701

介面與數組

註意一下我們的介面和數組怎麼來使用,長得很像索引簽名,但其實不是,前面定義的其實是我們數組的下標,所以只能為number類型,後面是數組裡面每一項的值類型

image-20221024105633413

4.5 介面繼承

介面可以繼承介面用到另一個介面上的屬性約束 extends

單繼承:

image-20221024110149886

多繼承:

用逗號隔開

image-20221024110254424

4.6 介面的混合類型

就是可以將介面裡面多個類型混合在一起定義,包括屬性、函數等

因為我們之前都是單獨對對象或者函數進行介面約束,那麼如果要進行一個混合類型介面,以函數為例,先綁定給一個函數

image-20221024114148152

函數裡面先定義好我們的函數,並且提示需要返回值

image-20221024114634510

添加返回值後提示缺少定義好的兩個屬性

image-20221024114654954

直接將counter類型斷言為Counter並將屬性綁定上去

可以看到此時這個counter即為函數又為對象

又可以使用自己函數,又可以調用對象屬性

image-20221024115057198

image-20221024115106225

image-20221024115113941

image-20221024115118507

image-20221024115122197

image-20221024115126387

4.7 介面和類型別名的異同點

主要是兩同兩異

相同一:

都可以描述屬性或者方法

這裡分別用類型別名和介面定義了兩個屬性一個方法,都沒有報錯

image-20221024115843551

應用上去也沒問題

image-20221024115947111

相同二:

都允許擴展

註意類型別名擴展是用&連接

image-20221024120143959

介面的擴展前面有說extends來連接

不同點一:

type可以聲明基本數據類型、聯合類型、數組等等,而介面只能聲明對象,函數也是對象

image-20221024120724487

註意:這是或者的意思,比如在數組那裡有且只有第一個值,有第二個值就會報錯

不同點二:

type不能進行合併,介面可以

image-20221024120901573

image-20221024120917758


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、什麼是 SQLite 資料庫 SQLite 是嵌入式SQL資料庫引擎。與大多數其他 SQL 資料庫不同,SQLite 沒有單獨的伺服器進程。SQLite 直接讀取和寫入普通磁碟文件。具有多個表,索引,觸發器和視圖的完整 SQL 資料庫包含在單個磁碟文件中。資料庫文件格式是跨平臺的-您可以在32位 ...
  • 我是風箏,公眾號「古時的風箏」,專註於 Java技術 及周邊生態。 文章會收錄在 JavaNewBee 中,更有 Java 後端知識圖譜,從小白到大牛要走的路都在裡面。 本來是一個平靜而美好的下午,其他部門的同事要一份數據報表臨時彙報使用,因為系統目前沒有這個維度的功能,所以需要寫個SQL馬上出一下 ...
  • 背景 監控、優化、診斷 cpu, io消耗監控https://github.com/powa-team/pg_stat_kcache where條件過濾性統計https://github.com/powa-team/pg_qualstats cgroup , /proc 系統級指標統計https:/ ...
  • dispatch_sync執行了兩件事:把代碼塊放入指定線程的任務隊列中、堵塞當前線程直到代碼塊執行結束,如果出現了堵塞的線程和代碼塊所在的線程為同一線程的話,這個時候代碼無法在此線程執行繼續下去,即造成了死鎖。 - (void)viewDidLoad { [super viewDidLoad]; ...
  • 隨著元宇宙的興起,3D虛擬現實廣泛引用,讓數字化信息和現實世界融合,目前大家的目光主要聚焦於視覺交互層面,為了在虛擬環境中更好的再現真實世界的三維空間體驗,引入聽覺層面必不可少,空間音頻孕育而生。 空間音頻是一種音頻體驗,會讓用戶更容易體驗到聲音的立體感和深度,將環繞聲更準確地定位在合適的方位,讓用 ...
  • 好家伙, 本篇內容為《JS高級程式設計》第三章學習筆記 1.數據類型 ECMAScript有6種簡單數據類型(稱為原始類型): Undefined, Null, Boolean, Number, String和Symbol。 Symbol (符號)是ECMAScript6新增的。還有一種複雜數據類型 ...
  • Ant Design Pro V5 訪問signalR : connection.start 沒反應, network顯示待處理, 原來是代理沒設置好,需要配置成支持websocket,配置如下圖所示。 ...
  • vue vue簡介 Vue (發音為 /vjuː/,類似 view) 是一款用於構建用戶界面的 JavaScript 框架。它基於標準 HTML、CSS 和 JavaScript 構建,並提供了一套聲明式的、組件化的編程模型,幫助你高效地開發用戶界面。無論是簡單還是複雜的界面,Vue 都可以勝任。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...