typeScript学习-函数重载

typeScript学习

函数重载

定义:一组具有相同名字,不同参数列表的和返回值无关并且具有一个实现签名和一个或多个重载签名的函数。

复制代码
type Messgae = {
    id: number,
    type: MessgaeType,
    sendmessage: string
}

enum MessgaeType {
    IMAGE = "image",
    AUDIO = "audio",

}
let message: Messgae[] = [
    { id: 1, type: MessgaeType.IMAGE, sendmessage: "你好啊, 今晚咱们一起去三里屯吧", },
    { id: 2, type: MessgaeType.AUDIO, sendmessage: "朝辞白帝彩云间,千里江陵一日还", },
    { id: 3, type: MessgaeType.AUDIO, sendmessage: "你好!张无忌", },
    { id: 4, type: MessgaeType.IMAGE, sendmessage: "刘老根苦练舞台绝技!", },
    { id: 5, type: MessgaeType.IMAGE, sendmessage: "今晚王牌对王牌节目咋样?", },
]

function searchMsg(condition: MessgaeType): Messgae[]; // 重载签名
function searchMsg(condition: number): Messgae | undefined // 重载签名
function searchMsg(condition: MessgaeType | number): Messgae | undefined | Messgae[] {
    // 实现签名
    if (typeof condition === 'number') {
        return message.find(msg => condition === msg.id)
    } else {
        return message.filter(msg => condition === msg.type)
    }

}


console.log(searchMsg(1)) // { id: 1, type: 'image', sendmessage: '你好啊, 今晚咱们一起去三里屯吧' }
searchMsg(MessgaeType.IMAGE).forEach(item => {
    console.log("item:", item)
    // item: { id: 1, type: 'image', sendmessage: '你好啊, 今晚咱们一起去三里屯吧' }
    // item: { id: 4, type: 'image', sendmessage: '刘老根苦练舞台绝技!' }
    // item: { id: 5, type: 'image', sendmessage: '今晚王牌对王牌节目咋样?' }
})

export { }
复制代码

 

posted on   空白格k  阅读(17)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示