typescript学习笔记——(一)基础类型

前段时间公司项目使用了ts做类型限制,虽然没有深入使用,但是已经能感受到ts的强大。遂将之前的学习笔记整理一遍以作复习。为vue3.0打好基础(大佬们别再学了,跟不上了-_-!!)。

你要知道的

TypeScript是JavaScript的超集,含了 JavaScript 的所有元素,可以载入 JavaScript 代码运行,并扩展了 JavaScript 的语法。
JavaScript是弱类型语言,何为弱类型呢?简单来说就是忽略类型的限制,一个变量可以赋值为任意类型的值。
TypeScript是强类型语言,与弱类型相反,也就是说一个变量声明时指定了类型,那么它就永远是这个类型,只能赋这个类型的值(除非经过强制类型转换)。
JavaScript是脚本语言,TypeScript是编译语言,就是说如果想执行一个ts文件,那么就要先将ts文件编译成js文件再去执行。
使用TS的好处,从现阶段来说,TS带给项目的好处显而易见,首先很多错误在编译阶段就会暴露出来。其次代码有更好的可读性和可维护性。

准备

掌握以下几个命令就可以开始学习TS
全局安装ts
npm i -g typescript
编译ts文件,执行命令后,同目录下会生成一个同名的js文件
tsc xxx.ts
执行
node xxx.js

基础类型

JavaScript的所有类型TS都支持,并且TS还扩展了如枚举等类型。变量的声明方式与JavaScript无异,只是加入了类型注解。
几种常见的类型

let flag: boolean = false // boolean
let num: number = 20 // number
let name: string = 'bob' // string
let list: number[] = [1, 2, 3, 4] // Array
let obj: Object = {} // Object

元组类型
元组就是已知长度和类型的数组

let arr: [string,number]
arr = ['halo', 10] 
arr = [10, 'halo'] // error 赋值的顺序要与声明时的顺序一致,否则会报错
arr[2] = 'wode' // 如此越界赋值,在3.1及以上版本会报错

枚举类型

enum Color1 {
    Red, // 索引默认从0,可以修改
    Green,
    Blue
}
enum Color2 {
    Red = 1, // 索引默认从0,可以修改
    Green = 2,
    Blue = 4
}

let c1: Color1 = Color1.Blue
let colorName: string = Color2[2] // 反查 Green

any任意类型
当不确定类型时可以使用any,表示任意类型

let notSure1: any = 4
let notSure2: any = 'str'
// any 类型的变了可以赋值成任意类型
notSure1 = 'maybe a string inttead'
notSure2 = false
// any 类型的数组,也可以赋值为任意类型
let notSureList: any[] = [1, true, 'dd']
notSureList[1] = 100

需要注意的是,类型注解为any代表任意类型,但是如果不写类型注意,TS会进行类型推断,推断为一个类型,此时该变量是有确定类型的不可随意赋值。如:

let notSure3 = 4 // 不写类型,会根据赋值进行推断,类型为number
notSure3 = 'to string' // error 

void类型
void 表示没有任何类型

// 一个没有返回值的函数
function fn(): void {
    console.log('this fnc has no return');
}

// 对于变量来说,意义不大
let unsable: void = null // 还可以赋值为undefined,赋值其他会报错

null & undefined
赋值成这两种类型没有实际意义

let num: number = 5
num = null // 正常编译不会报错,但是使用 tsc xx.ts --strictNullChecks严格模式编译会报错
// 使用联合类型,联合类型表示或的关系
let num2: number | null = 3
num2 = null

never类型
表示不存在的类型,是所有类型的子类型。never可以赋值给其他类型,其他类型不能赋值给never。

let test1: number = 123
let test2: never
test1 = test2
// test2=test1 // error 

function error(message: string): never {
    throw new Error(message)
}
function fail() {
    return error('some failed')
}

类型断言

有时可以明确指定一个变量为某种类型,类型断言两种常见方式

let someVal: any = 'this is a string'
let strLen1: number = (<string>someVal).length
let strLen2: number = (someVal as string).length

更推荐使用第二种方式。

解构赋值

let o = {
    a1: 'foo',
    b1: 12,
    c1: 'bar'
}
let { a1, b1 }: { a1: string, b1: number } = o;
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容

  • 基础语法 ts程序组成部分 模块、函数、变量、语句和表达式、注释 一些注意 - ts会忽略程序中的空格、制表符和换...
    玛丽莲做梦阅读 711评论 0 0
  • 简介 TypeScript 是 JavaScript 的一个超集,主要提供了 类型系统 和对 ES6 的支持,由 ...
    MrWelson阅读 15,891评论 3 21
  • TypeScript 是微软开发和控制的开源项目,我在应用 Anguar 2+ 和 Ionic 2+ 框架开发系统...
    廖全磊LesterLiao阅读 1,625评论 0 3
  • 一、什么是 TypeScript? 百度解释:TypeScript是一种由微软开发的自由和开源的编程语言。它是Ja...
    wave浪儿阅读 2,216评论 1 20
  • 前言 现在TypeScript越来越火,咱也赶一下潮流,开始学习一下TypeScript,在学习的同时做笔记记录,...
    郝晨光阅读 1,457评论 0 7