TS-interface

TS学习

Interface(接口)

基本使用

interface LabelValue{
    label:string;
}
function printLabel(labelObj:LabelValue){
    console.log(labelObj.label)
}
let myObj = {label:"hello"};
printLabel(myObj)

可选属性

interface USB{
    name:string;
    age?:number;
}
function printUSB(pu:USB){
    if(pu.age){
        console.log(pu.name +":" +pu.age)
    }else{
        console.log(pu.name)
    }
}
let my={name:"ime"}
let my1 ={name:"liao",age:18}
printUSB(my1)

函数类型

interface SearchFunc{
    (source:string,subString:string):boolean;
}
let mySearch:SearchFunc;
mySearch = function(str:string,sub:string){
    let result = str.search(sub)
    if(result != -1){
        return true
    }else{
        return false
    }
}
let r = mySearch("string","str")
console.log(r) //true

接口的数组类型

interface StringArray{
    [index:number]:string
}
let myArr:StringArray;
myArr =["a","b"];
alert(myArr[0]);

class实现接口

interface ColockInterface{
    currentTime:Date;
    setTime(d:Date);
}
class Clock implements ColockInterface{
    currentTime:Date;
    setTime(d:Date){
        this.currentTime = d
    }
    constructor(h:number,m:number){  
    }
}

接口类型与混合类型

interface Shape{
    color:string
}
interface PenStroke{
    penWidth:number
}
interface Square extends Shape,PenStroke{
    sideLength:number
}
let s = <Square>{};
s.color = "bule"
s.penWidth = 10
s.sideLength =10

混合接口

interface Counter{
    interval:number;
    reset():void;
    (start:number):string
}
let c:Counter;
c(10)
c.reset()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值