typescript_对象类型接口_详细

1.参数固定属性,且函数返回值必须是number类型
let isAdd : (x : number , y : number) => number;
2.参数固定属性,且函数返回值必须是number类型,跟上面是等价的
interface Add {
     (x:number , y:number) : number
 }
3.类型别名,相当于给函数起一个名字
type Add = (x: number , y: number) => number;
let isadd : Add = (x:number , y:number) => {return x + y};
4.混合接口
//就像定义一个对象一样,即可定义一个函数也可以定义一个参数
interface  Lib {
    ():void,
    version : string,
    doSomething():void
}
let lib : Lib = (() => {}) as Lib;
lib.version = "1.0";
lib.doSomething = () => {};

//上面的写法相当于全局暴露了一个Lib,这是一个单例,如果我想创建多个Lib,可以使用函数包裹
function getLib(){
    let lib : Lib = (() => {}) as Lib;
    lib.version = "1.0";
    lib.doSomething = () => {};
    return lib;
}
let lib1 = getLib();
lib1.doSomething();

let lib2 = getLib();
lib2.doSomething();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值