TS 函数 配合接口

指定类型

声明函数时,大致和 vue2 一样,多了可以指定 参数 和 返回值 的类型,

直接看例子

function sum(x:number, y:number) {
    return x + y;
}

function sum(x, y):number {
    return x + y;
}

我们 现在有 sum 函数,第一个 sum 指定了 参数类型, 第二个指定了 返回值类型,使用一下函数

sum('1',2)	// 报错

sum('1',2)	// 报错

 两次使用都会报错,但是报错信息不一样:

1. x、y类型必须都是number类型

2. 参数 '1',2 进行的是字符串拼接,所以返回值是string,不是number类型

?可选参数

使用 ‘?’ 指定参数为可选参数,需要正常参数后定义

function sum(x:number, y?:number) {
    console.log(x,y);
}

sum(1)

可以看到,我们不穿传 y 不报错,并且 y 的值为 undefined 

默认参数

和vue2 一样,直接看例子

function sum(x:number, y?:number,z=10) {
  console.log(x,y,z);
}
sum(1)

 剩余参数

function sum(x:number,y:number,...result:number[]):number{}

通过 ...result 获取剩余参数 (result可以改成别的名字),

:需要注意这个参数的类型,是个数组但是,可能你在使用时不是 数字数组( number[] ),注意好指明类型就好

配合接口

现在我们可以使用接口,更规范的定义 参数 返回值,返回值例子:

interface Back {
    bark: Function
}
interface Person {
    name: string,
    age: number
}
type MergeType = Person & Back 
function funcMerge(): MergeType {
    let zs: Person  = {
        name: "zs",
        age: 18
    }
    let back : Back = {
        bark: () => {
            console.log('holle')
        }
    }
    return Object.assign(zs, back )
}

可以看到上面例子中 函数的返回值 为两个合并的接口,最后返回 一个 对象 和 一个方法,

当然参数类型也可以这样定义

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值