typescript入门

js数据类型:

7种原始类型:Boolean Null Undefined Number Bigint String Symbol
Object 类型

let isDone: boolean = false
let num: number = 10
let str: string = `
num = ${num}
isDone = ${isDone}
`
let u: undefined = undefined
let n: null = null

// any 类型数据,就像js种变量。避免使用
let notSure: any = 4
notSure = 'sdsd'
notSure = true
notSure.fun()
notSure.attr

// 数组
let arrNum: number[] = [1,2,3]
let arrStr: string[] = ['1','2','3']

// array-like object,类似数组,但是没有 push pop 等操作
function test(param1:any) {
    // arguments 为ts内置的类数组
    console.log(arguments[0]);
    console.log(arguments.length);
}

// tuple
let user: [string, number] = ['name', 1]

接口

// 接口
interface Person {
    readonly id: number // 只读属性
    name: string
    age?: number   // 可选字段
}

let a: Person = {
    id: 1,
    name: 'aaaa',
    // age: 1,
}

函数

// 函数
interface AddFun {
    (x: number, y: number, z?:number):number
}

function fun(a:number, b:number = 0, c?:number) :number {
    if (typeof c === 'number') {
        return a + b + c
    } else {
        return a + b
    }
}

fun(1)
fun(1,1)
fun(1,2,2)

let f: AddFun = fun

联合类型 类型断言

// union types, 只能访问所有类型都拥有的属性或方法
let numOrStr : number|string
numOrStr = 'abc'
numOrStr = 1


// 类型断言,不是类型转化,将变量断言为联合类型中不存在类型会出错
function getLength(input: string|number) :number {
    const str = input as string
    if (str.length) {
        return str.length
    } else {
        const number = input as number
        return number.toString().length
    }
}
getLength(numOrStr)

// type guard
function getLength2(input: string|number) :number {
    if (typeof input === 'string') {
        return input.length
    } else {
        return input.toString().length
    }
}

Public 默认;Private ;Protected 子类允许访问
class Animal {
    readonly name: string;               // 在ts中类的属性在此声明,使用readonly声明为只读
    constructor(name: string) {
        this.name = name
    }
    protected run() {
        return `${this.name} is running`
    }
}
const snake = new Animal('aaa')
console.log(snake.run())              // 此处无法调用

class Dog extends Animal {
    static categories = ['Animal']
    constructor(name: string) {
        super(name)
        console.log(this.name)
    }
    bark() {
        return `${this.name} is barking`
    }
    run() {
        return `被重写:` + super.run()  // 此处可以访问
    }
}
const d = new Dog('ddd')
console.log(d.bark())
console.log(d.run())
console.log(Dog.categories)

接口与类

interface Radio {
    switchRadio(trigger: boolean): void;
}
interface Battery {
    switchBatteryStatus() : void;
}
interface RadioWithBattery extends Radio, Battery {
    checkBatteryStatus(): void;
}

class Car implements Radio {
    switchRadio(trigger: boolean): void {
    }
}

class Cellphone implements RadioWithBattery {
    checkBatteryStatus(): void {
    }
    switchRadio(trigger: boolean): void {
    }
    switchBatteryStatus(): void {
    }
}

枚举类
对于常量值,在 enum 前加上 const,开始内联,将所有使用枚举值的地方改为常量,提升性能

enum Direction {
    Up,        // 0
    Down = 10, // 10
    Left,      // 11
    Right,     // 12
}
console.log(Direction.Up) // 0
console.log(Direction[0]) // Up


enum Direction {
    Up = 'UP',
    Down = 'DOWN',
    Left = 'LEFT',
    Right = 'RIGHT',
}
if ('UP' === Direction.Up) {
    console.log('go up')
}

 泛型

function echo<T>(arg: T): T {
    return arg
}
let str = 'string'
let res = echo(str)
let resNum = echo(123)

function swap<T, U>(tuple: [T, U]): [U, T] {
    return [tuple[1], tuple[0]]
}
let t: [number, string] = [1, 'a']
let resTuple: [string, number] = swap(t)

// 泛型约束
interface IWithLength {
    length: number
}
function getLenth<T extends IWithLength>(arg: T): number {
    return arg.length
}
getLenth('123')
getLenth([1,2,3])
getLenth({'1':1, '2':2})

 泛型与类、接口

class Queue<T> {
    private data: T[] = [];
    push(item: T) {
        return this.data.push(item)
    }
    pop(): T|undefined {
        return this.data.shift()
    }
}

const q = new Queue<number>()
q.push(1)
q.push(2)
// q.push('12') // error
q.pop()
q.pop()

interface KeyPair<T, U> {
    key: T,
    value: U,
}
let kp1: KeyPair<string, number> = {key: '1', value: 1}

// 内置类型
let p1: Array<number> = [1,2,3]

类型别名,字面量 和 交叉类型

// 类型别名
type PluseType = (x: number, y: number) => number
let sumFun: PluseType

type int = number
type StrOrNum = string | number

// 类型为原始类型,
const str: 'name' = 'name'
const num: 1 = 1

// 字面量与类型别名组合
type Directions = 'Up'|'Down'|'Left'|'Right'
let toWhere: Directions = 'Left'

// 交叉类型
interface IName {
    name: string
}
type IPerson = IName & {age: number}
let person: IPerson = {name: '123', age: 123}

 声明文件

TS调用js库如jQuery,需要使用 declare var 声明变量已存在,然后直接使用。通常将声明语句放在一个单独的文件,如 jQuery.d.ts。可通过 npm install --save @types/jquery 安装jQuery的声明文件。

内置类型

在全局作用域存在的对象(ECMAscript,DOM等标准),

 

// global objects
const a: Array<number> = [1,2,3]
const data = new Date()
const reg: RegExp = /abc/


// build-in object
Math.pow(2,2)

// DOM and BOM
let body = document.body
let allLis = document.querySelectorAll('li')
document.addEventListener('click', (e)=>{
    e.preventDefault()
})

// Utility Types
// Ts提供的工具类 https://www.typescriptlang.org/docs/handbook/utility-types.html

 

posted @ 2023-01-30 18:47  某某人8265  阅读(23)  评论(0编辑  收藏  举报