TS学习笔记 --(一)

TS学习笔记

一、类型注解

eg:

function greeter(person: string) {
    return `Hello ${person}` 
}

const user = 'chenhe'
console.log(greeter(user))  // Hello chenhe

二、定义接口

eg:

interface Person {
    firstName: string
    lastName: string
}

function greeter(person: Person) {
    return `Hello ${person.firstName} ${person.lastName}`
}

let user = {
    firstName: 'chenhe',
    lastName: 'zhengkai'
}
console.log(greeter(user)) // Hello chenhe zhengkai

ES6版:

class User {
    firstName: string
    lastName: string
    
    constructor(firstName: string, lastName: string) {
        this.firstName = firstName
        this.lastName = lastName
    }
}

interface Person {
    firstName: string
    lastName: string
}

function greeter(person: Person) {
    return `Hello ${person.firstName} ${person.lastName}`
}

let user = new User('chenhe', 'zhengkai')
console.log(greeter(user)) // Hello chenhe zhengkai

三、基础类型

Boolean、Number、String、Array、元组、枚举、Any、Void、Null、Undefined、Object、类型断言

1. Boolean

let isDone: boolean = true
let isDone: boolean = false 

2. Number

let decLiteral: number = 20  // 十进制
let binaryLiteral: number = 0b10100  // 二进制 
let octalLiteral: number = 0o24  // 八进制
let hexLiteral: number = 0x14  // 十六进制

3. String

let name: string = 'chenhe'
let name: string = `chenhe`

4. Array

let list: number[] = [1,2,3]
let list: Array<number> = [1,2,3] 

5. 元组

let x: [string, number]
x = ['hello', 20]

6. 枚举

enum Color {
    Red = 1,
    Green,
    Blue
}

let colorName: string = Color[2]
console.log(colorName)  // Green

7. Any

let notSure: any = 4  //  不作类型检查 
notSure = 'Hello'
notSure = false

let list: any[] = [1, true, 'free']

8. void

function warnUser(): void {
    conslole.log(`This is a warning message!`)
}

9. null

let n: null = null

10. undefined

let n: undefined = undefined

11. never

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

function infiniteLoop(): never {
    while(true) {
        ...
    }
}

12. Object

declare function create(o: object | null): void {
    // declare --- 声明   
}

create(o: {prop: 0})   // OK
create(o: null)   // OK

create(o: 42)    // NO
create(o: 'string')   // NO
create(o: false)   // No

13. 类型断言

let someValue: any = `this is a string`
let strLength: number = (someValue as string).length

四、变量声明

后续待更......

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值