TypeScript学习笔记

1.基础类型

布尔,数字,字符串,数组,元组Tuple,枚举,任意值,空值,null和undefined

1.1 元组Tuple

元组类型允许表示一个已知元素数量和类型的数组,各元素的类型不必相同。 比如,你可以定义一对值分别为stringnumber类型的元组。

javascript 复制代码
let x: [string, number];
// Initialize it
x = ['hello', 10]; // OK

1.2 枚举

javascript 复制代码
enum Color {Red, Green, Blue};
let c: Color = Color.Green;

1.3数组

javascript 复制代码
let list: number[] = [1, 2, 3];

第二种方式是使用数组泛型,Array<元素类型>

javascript 复制代码
let list: Array<number> = [1, 2, 3];

1.4 布尔

javascript 复制代码
let isDone: boolean = false;

1.5 数字

javascript 复制代码
let decLiteral: number = 6;

1.6 字符串

javascript 复制代码
let name: string = "bob";
name = "smith";

2.解构赋值

2.1解构数组

javascript 复制代码
let [first, ...rest] = [1, 2, 3, 4];
console.log(first); // outputs 1
console.log(rest); // outputs [ 2, 3, 4 ]

2.2 对象解构

javascript 复制代码
let o = {
    a: "foo",
    b: 12,
    c: "bar"
}
let {a, b} = o;

3 接口

javascript 复制代码
interface LabelledValue {
  label: string;
}

function printLabel(labelledObj: LabelledValue) {
  console.log(labelledObj.label);
}

let myObj = {size: 10, label: "Size 10 Object"};
printLabel(myObj);

类型检查器不会去检查属性的顺序,只要相应的属性存在并且类型也是对的就可以。

3.1 可选属性

带有可选属性的接口与普通的接口定义差不多,只是在可选属性名字定义的后面加一个?符号。

可选属性的好处之一是可以对可能存在的属性进行预定义,好处之二是可以捕获引用了不存在的属性时的错误。

3.2 只读属性

一些对象属性只能在对象刚刚创建的时候修改其值。 你可以在属性名前用readonly来指定只读属性:

javascript 复制代码
interface Point {
    readonly x: number;
    readonly y: number;
}

3.3 reladonly 和const的区别

做为变量使用的话用const,若做为属性则使用readonly

3.4 函数类型

为了使用接口表示函数类型,我们需要给接口定义一个调用签名。 它就像是一个只有参数列表和返回值类型的函数定义。参数列表里的每个参数都需要名字和类型。

javascript 复制代码
interface SearchFunc {
  (source: string, subString: string): boolean;
}

这样定义后,我们可以像使用其它接口一样使用这个函数类型的接口。

javascript 复制代码
let mySearch: SearchFunc;
mySearch = function(source: string, subString: string) {
  let result = source.search(subString);
  if (result == -1) {
    return false;
  }
  else {
    return true;
  }
}

3.5 接口扩展 extends

javascript 复制代码
interface Shape {
    color: string;
}

interface Square extends Shape {
    sideLength: number;
}

let square = <Square>{};
square.color = "blue";
square.sideLength = 10;

4 类

下面看一个使用类的例子:

javascript 复制代码
class Greeter {
    greeting: string;
    constructor(message: string) {
        this.greeting = message;
    }
    greet() {
        return "Hello, " + this.greeting;
    }
}

let greeter = new Greeter("world");
相关推荐
东方芷兰7 分钟前
LLM 笔记 —— 07 Tokenizers(BPE、WordPeice、SentencePiece、Unigram)
人工智能·笔记·深度学习·神经网络·语言模型·自然语言处理·nlp
不会kao代码的小王15 分钟前
从本地到云端:Fiora+cpolar打造真正的私密社交通讯站
笔记
fanstering20 分钟前
深度相机初探:立体视觉(Stereo Vision)、结构光(Structured Light)、TOF(Time of Flight,飞行时间)
笔记·数码相机·立体视觉·结构光·tof
长沙红胖子Qt24 分钟前
FFmpeg开发笔记(十三):ffmpeg采集麦克风音频pcm重采样为aac录音为AAC文件
笔记·ffmpeg·音视频
酌量28 分钟前
路径平滑优化详解(二次规划): 数学建模与目标函数推导
经验分享·笔记·学习·机器人·自动驾驶
泽虞31 分钟前
《Qt应用开发》笔记p3
linux·开发语言·数据库·c++·笔记·qt·面试
泽虞1 小时前
《Qt应用开发》笔记p4
linux·开发语言·数据库·c++·笔记·qt·算法
泽虞1 小时前
《Qt应用开发》笔记p5
linux·开发语言·c++·笔记·qt·算法
hour_go2 小时前
页表 vs. 组相联缓存:内存管理与性能优化的殊途同归
笔记·操作系统·分页·计算机体系结构·tlb·组相联缓存
爱倒腾的老唐3 小时前
01、如何学习单片机
单片机·嵌入式硬件·学习