欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Typescript中的數(shù)據(jù)類型實例總結(jié)

 更新時間:2022年03月25日 11:45:54   作者:用戶名為空_  
ts中數(shù)據(jù)類型的定義是重點之一,所以必須明確ts有哪些數(shù)據(jù)類型,下面這篇文章主要給大家介紹了關(guān)于Typescript中數(shù)據(jù)類型的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

是什么

typescript和javascript幾乎一樣,擁有相同的數(shù)據(jù)類型,另外在javascript基礎(chǔ)上提供了更加實用的類型供開發(fā)使用。

在開發(fā)階段,可以為明確的變量定義為某種類型,這樣typescript就能在編譯階段進行類型檢查,當類型不符合預期結(jié)果的時候則會出現(xiàn)錯誤提示

有哪些

typescript的數(shù)據(jù)類型主要有如下:

  • 1、boolean(布爾類型)
  • 2、number(數(shù)字類型)
  • 3、string(字符串類型)
  • 4、array(數(shù)組類型)
  • 5、tuple(元組類型)
  • 6、enum(枚舉類型)
  • 7、any(任意類型)
  • 8、null和undefined類型
  • 9、void類型
  • 10、never類型
  • 11、object(對象類型)

boolean

let flag:boolean = true;
flag = 123;    // 錯誤
flag = false;  // 正確

number

數(shù)字類型,和javascript一樣,typescript的數(shù)值類型都是浮點數(shù),可支持二進制、八進制、十進制和十六進制。

let num:number = 123;
num = '456';   // 錯誤
num = 456;     // 正確

進制表示:

let decLiteral:number = 6; // 十進制
let hexLiteral:number = 0xfood; // 十六進制
let binaryLiteral:number = 0b1010; // 二進制
let octalLiteral:number = 0o744; // 八進制

string

字符串類型,和javascript一樣,可以使用雙引號(")或單引號(')表示字符串

let str:string = 'this is ts';
str = 'test';

作為超集,當然也可以使用模板字符串進行包裹,通過${}嵌入變量

let name:string = `Gene`;
let sentence:string = `Hello, my name is ${name}`

array

數(shù)組類型,跟javascript一致,通過[]進行包裹,有兩種寫法:

方式一:元素類型后面接上[]

let arr:string[] = ['12','23'];
arr = ['45','56'];

方式二:使用數(shù)組泛型,Array<元素類型>:

let arr:Array<number> = [1,2];
arr = ['45','55'];

tuple

元組類型,允許表示一個已知元素和類型的數(shù)組,各元素的類型不必相同

let tupleArr:[number,string,boolean];
tupleArr = [12,'34',true]; // yes
tupleArr = [12,'34']; // no

enum

enum類型是對javascript標準數(shù)據(jù)類型的一個補充,使用枚舉類型可以為一組數(shù)值賦予友好的名字

enum Color {Red,Green,Blue}
let c:Color = Color.Green;

any

可以指定任何類型的值,在編程階段還不清楚類型的變量指定一個類型,不希望類型檢查器對這些值進行檢查而是直接讓它們通過編譯階段的檢查,這時候可以使用any類型

使用any類型允許被賦值為任意類型,甚至可以調(diào)用其屬性、方法

let num:any = 123;
num = 'str';
num = true;

定義存儲各種類型數(shù)據(jù)的數(shù)組時,示例代碼如下:

let arrayList:any[] = [1,false,'fine'];
arrayList[1] = 100;

null和undefined

在javascript中null表示 “什么都沒有”,是一個只有一個值的特殊類型,表示一個空對象引用,而undefined表示一個沒有設(shè)置值的變量。

默認情況下null和undefined是所有類型的子類型,就是說你可以把null和undefined賦值給number類型的變量

let num:number | undefined; // 數(shù)值類型或者undefined
console.log(num); // 正確
num = 123; 
console.log(num); // 正確

但是ts配置了--strictNullChecks標記,null和undefined只能賦值給void和它們各自

void

用于標識方法返回值的類型,表示該方法沒有返回值。

function hello():void {
    alert('Hello Runoob')
}

never

never是其他類型(包括null和undefined)的子類型,可以賦值給任何類型,代表從不會出現(xiàn)的值,

但是沒有類型是never的子類型,這意味著生命never的變量只能被never類型所賦值。

never類型一般用來指定哪些總是會拋出異常,無限循環(huán)

let a:never;
a = 123; // 錯誤的寫法

a = (() => { // 正確的寫法
    throw new Errow('錯誤')
})()

// 返回的never的函數(shù)必須存在無法達到的終點
function error(message:string): never {
    thorw new Error(message);
}

object

對象類型,非原始類型,常見的形式通過{}進行包裹

let obj:object;
obj = {name:'Zhang',age:23};

總結(jié)

和javascript基本一致,也分成:

  • 1、基本類型
  • 2、引用類型

在基礎(chǔ)類型上,typescript增添了void、any、emun等原始類型。

到此這篇關(guān)于Typescript數(shù)據(jù)類型的文章就介紹到這了,更多相關(guān)Typescript數(shù)據(jù)類型內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論