TypeScript

安装 npm i typescript

tsc --help脚手架帮助命令

tsc --init初始化文件

tsc --watch自动检测

把ts文件编译成js文件:tsc ./src/app.ts --outFile ./dist/app.js

基础

//常量定义
let hd:string = 'hd'
let hd:number = 123
let hd:boolean = true
//数组定义
//定义一个数组的值,只能是nmber | string
const hd (nmber | string)[] = []
//范性
const hd :Array<string> = []//里面必须是字符串
//对象定义
let hd:object
//url后的问号表示这个参数是可选项
let hd:{ name:string , age:number , url?:string }
hd = { name:'string' , age:123 }
//组合定义 定义的变量可以是多种类型
let hd: string | number //定义字符串或者数字都行
let hd: (string | number)[]

let day: string | number | boolean
day = 'da'
day = 1
day = true

//范性
let hd :Array<string | number> = []
//any 任何类型都可 不会进行校验
let hd:any[] = []
//unknown
let hd:string = '99'
let a:number = hd as unkonwn as number
//void 函数返回结果为null或者undefeated
function hd():void{}
//never 什么都没有 就是不会执行到头 用于死循环 无返回值类型(不确定值类型)
function hd():never{
  throw new Error('err')
}
//null undefeated
//Null Undefined是所有类型的子类型
let hd:null = null
let hd:undefeated = undefeated
//函数声明
let func:Function = (a:number,b:number,c?:number)=>{
  //c是可选参数
  return a + b + c 
}
//设定返回值 void表示没有返回值
function msg():void {console.log(123)}
function sum(a:number,b:number):number {return a + b}
//使用type对函数进行声明
type userType = {name:string,age:number}
let addUser = (user:userType):void ={ console.log('添加用户')}
//函数的结构定义
type userType = {name:string,age:number}
type userAddFun = (user:userType) => boolean
let addUser:userAddFun = (user:userType):boolean =>{
  console.log('add')
    return true
}
addUser({name:'hd',age:123})
//函数剩余参数
function sum(...args:number[]):number {
  return args.reduce((s,n)=>s+n,0)
}
sum(1,2,3)

枚举

enum Sextype {
  BOY,
  GIRL
}
console.log(Sextype.BOY)//0 打印出来的是默认下标 如果赋值则是值
//-——————————————————
enum Color {
    Red=2, Green=5, Blue=9
}

let c: Color = Color.Green
console.log(c)//5
let Colorname: string = Color[5]
console.log(Colorname)//Green

断言

把结果输出为指定的值

function hd (arg:boolean):'指定的值'{
  //return arg //报错
  return '指定的值'
}
const res = hd(true)

//元组 Tuple
let a = 'string'
let b = 123
let hd = <const>[a,b]
let f = hd[1] //这时候的类型是数字 如果不加const就是数字或字符串

let x: [string,number]
//只能这个位置来加元素,而且只能加两个元素(数组有顺序)
x = ['hello',2]//不能越界访问,比如访问x的第四个元素

class User {
  name:string
  age:number
  constructor(n:string,a:number){
    this.name = n
    this.age = a
  }
  info():string{
    return this.name
  }
}
const hd = new User('kk',1)
const hd2 = new User('cc',2)
const users:User[] = [] // 给数组定义元素为当前这个user类
users.push(hd,hd2)

泛形 generics

不确定类型

//T就表示泛形 string就是设置的类型
function dump<T>(arg:T):T {
  return arg
}
let hd = dump<string>('hd') // string

//public 公开
class User {
  //readonly只能取不能改
  public readonly name:string // 都可以用
  protected age:number //protected可以在子类中访问,不能在实现对象中访问  子类能覆盖但是权限不能大于父类 只能public
  private gender:string //。在子类和类的实现的对象中都不能访问。在子类可以通过调用使用这个属性的方法来间接来使用这个属性。 子类不能覆盖
  constructor(n:string,a:number){
    this.name = n
    this.age = a
  }
  info():string{
    return this.name
  }
}
//继承
function getLength<T extends any[] | string>(agr:T):T{
  return arg.length
}
getLength('sadas')
getLength(['sadas'])
// 定义为有长度的值
type sType = { length:number }
let a:sType = '131' 
let a:sType = 131 // 报错 因为数字没有长度 

//类
class Collection<ZY> {
  data:ZY[] = []
  public push(...items:ZY[]){
    this.data.push(...items)
  }
  public shift():ZY {
    return this.data.shift()
  }
}
type User = { name:string,age:number }
const user:User = { name:'kk',age:12 }
const collections = new Collection<User>
collections.push(user) //  { name:'kk',age:12 }

//构造函数用泛形
class User<ZY> {
  public constructor(private _user){
    public get():ZY{
      return _user
    }
  }
}
//interface跟type大致一样
//interface能够创建一个新的类型,type不能创建一个新的类型
interface UserInterface { 
  name:string,
  age?:number,//加了?表示这个属性为可选
  [propName: string]:any //索引签名,后面定义的属性的类型可以是任意 propName为随意定义的值
}
const obj = new User<UserInterface>( { name:'kk',age:123 } )
obj.get().age // 123

//定义接口
interface jiekou<B,C>{
  title:B,
  isLock:C,
  comments:C[]
}

type CommentType = {
  content:string,
    author:string
}

const hd :jiekou<boolean,CommentType> = {
  title:'kk',
  isLock:true,
  comments:[{content:'123',author:'234'}]
}

get set

class User {
  private _name:string
  constructor(name:string){
    this._name = name
  }
  //get set 计算数据处理
  public get name():string {
    return this._name.substr(0,1)
  }
  public set name(name:string){
    this._name = name
  }
}
const hd = new User('kkk')
hd.name = 'air'

抽象abstract

abstract class Animation {
  //abstract只能在abstract类里定义 就是定义个模糊的东西 不具体 可以继承 但是如果继承的子类不用回报错
  abstract name:string
  abstract move():void
  protected getPods():number[]{
    return [2,3]
  }
}
let animal = new Animal()//报错,抽象类不能有实例化

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

推荐阅读更多精彩内容